summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Deucher <alex@t41p.hsd1.va.comcast.net>2007-05-25 23:29:51 -0400
committerAlex Deucher <alex@t41p.hsd1.va.comcast.net>2007-05-25 23:29:51 -0400
commitceec3f62257bafe4771e75d3c4f1d2a517d7acf8 (patch)
tree3451483fc2866d9ddbb6d56f129258cf6de683bb
parente3e9c608651e7cbb9851489274815f47d2a8dbbb (diff)
RADEON: implement auto/analog/digital output property for DVI-I (untested)
-rw-r--r--src/radeon_output.c76
-rw-r--r--src/radeon_probe.h8
2 files changed, 63 insertions, 21 deletions
diff --git a/src/radeon_output.c b/src/radeon_output.c
index 4e2fa0c2..0ea6d650 100644
--- a/src/radeon_output.c
+++ b/src/radeon_output.c
@@ -335,11 +335,27 @@ static xf86OutputStatus
radeon_detect(xf86OutputPtr output)
{
ScrnInfoPtr pScrn = output->scrn;
+ RADEONInfoPtr info = RADEONPTR(pScrn);
RADEONEntPtr pRADEONEnt = RADEONEntPriv(pScrn);
RADEONOutputPrivatePtr radeon_output = output->driver_private;
radeon_output->MonType = MT_UNKNOWN;
RADEONConnectorFindMonitor(pScrn, output);
+
+ /* force montype based on output property */
+ if (radeon_output->type == OUTPUT_DVI) {
+ if ((info->IsAtomBios && radeon_output->ConnectorType == CONNECTOR_DVI_I_ATOM) ||
+ (!info->IsAtomBios && radeon_output->ConnectorType == CONNECTOR_DVI_I)) {
+ if (radeon_output->MonType > MT_NONE) {
+ if (radeon_output->DVIType == DVI_ANALOG)
+ radeon_output->MonType = MT_CRT;
+ else if (radeon_output->DVIType == DVI_DIGITAL)
+ radeon_output->MonType = MT_DFP;
+ }
+ }
+ }
+
+
if (radeon_output->MonType == MT_UNKNOWN) {
output->subpixel_order = SubPixelUnknown;
return XF86OutputStatusUnknown;
@@ -383,6 +399,7 @@ static void
radeon_create_resources(xf86OutputPtr output)
{
ScrnInfoPtr pScrn = output->scrn;
+ RADEONInfoPtr info = RADEONPTR(pScrn);
RADEONOutputPrivatePtr radeon_output = output->driver_private;
INT32 range[2];
int data, err;
@@ -434,27 +451,30 @@ radeon_create_resources(xf86OutputPtr output)
}
}
- /* force analog/digital for DVI-I ports */
- /* FIXME: make sure this is DVI-I */
+ /* force auto/analog/digital for DVI-I ports */
if (radeon_output->type == OUTPUT_DVI) {
- monitor_type_atom = MAKE_ATOM("MONITORTYPE");
-
- range[0] = 0;
- range[1] = 1; // i830_lvds_get_max_backlight(pScrn);
- err = RRConfigureOutputProperty(output->randr_output, monitor_type_atom,
- FALSE, TRUE, FALSE, 2, range);
- if (err != 0) {
- xf86DrvMsg(pScrn->scrnIndex, X_ERROR,
- "RRConfigureOutputProperty error, %d\n", err);
- }
- /* Set the current value of the backlight property */
- data = 0; //pI830->backlight_duty_cycle;
- err = RRChangeOutputProperty(output->randr_output, monitor_type_atom,
- XA_INTEGER, 32, PropModeReplace, 1, &data,
- FALSE, TRUE);
- if (err != 0) {
- xf86DrvMsg(pScrn->scrnIndex, X_ERROR,
- "RRChangeOutputProperty error, %d\n", err);
+ if ((info->IsAtomBios && radeon_output->ConnectorType == CONNECTOR_DVI_I_ATOM) ||
+ (!info->IsAtomBios && radeon_output->ConnectorType == CONNECTOR_DVI_I)) {
+ monitor_type_atom = MAKE_ATOM("MONITORTYPE");
+
+ range[0] = DVI_AUTO;
+ range[1] = DVI_ANALOG;
+ err = RRConfigureOutputProperty(output->randr_output, monitor_type_atom,
+ FALSE, TRUE, FALSE, 2, range);
+ if (err != 0) {
+ xf86DrvMsg(pScrn->scrnIndex, X_ERROR,
+ "RRConfigureOutputProperty error, %d\n", err);
+ }
+ /* Set the current value of the backlight property */
+ radeon_output->DVIType = DVI_AUTO;
+ data = DVI_AUTO;
+ err = RRChangeOutputProperty(output->randr_output, monitor_type_atom,
+ XA_INTEGER, 32, PropModeReplace, 1, &data,
+ FALSE, TRUE);
+ if (err != 0) {
+ xf86DrvMsg(pScrn->scrnIndex, X_ERROR,
+ "RRChangeOutputProperty error, %d\n", err);
+ }
}
}
@@ -465,13 +485,27 @@ radeon_set_property(xf86OutputPtr output, Atom property,
RRPropertyValuePtr value)
{
ScrnInfoPtr pScrn = output->scrn;
+ RADEONOutputPrivatePtr radeon_output = output->driver_private;
+ INT32 val;
+
if (property == backlight_atom) {
return TRUE;
} else if (property == rmx_atom) {
return TRUE;
} else if (property == monitor_type_atom) {
- return TRUE;
+
+ if (value->type != XA_INTEGER ||
+ value->format != 32 ||
+ value->size != 1) {
+ return FALSE;
+ }
+
+ val = *(INT32 *)value->data;
+ if (val < DVI_AUTO || val > DVI_ANALOG)
+ return FALSE;
+
+ radeon_output->DVIType = val;
}
return TRUE;
diff --git a/src/radeon_probe.h b/src/radeon_probe.h
index 68873880..cccf7836 100644
--- a/src/radeon_probe.h
+++ b/src/radeon_probe.h
@@ -108,6 +108,13 @@ typedef enum
TMDS_NONE = 2
} RADEONTmdsType;
+typedef enum
+{
+ DVI_AUTO,
+ DVI_DIGITAL,
+ DVI_ANALOG
+} RADEONDviType;
+
typedef struct {
CARD32 freq;
CARD32 value;
@@ -143,6 +150,7 @@ typedef struct _RADEONOutputPrivateRec {
void *dev_priv;
RADEONDDCType DDCType;
RADEONDacType DACType;
+ RADEONDviType DVIType;
RADEONTmdsType TMDSType;
RADEONConnectorType ConnectorType;
RADEONMonitorType MonType;