diff options
author | Alex Deucher <alex@botch2.com> | 2007-08-05 02:27:32 -0400 |
---|---|---|
committer | Alex Deucher <alex@botch2.com> | 2007-08-05 02:27:32 -0400 |
commit | ba5496ae7973786802962bf649dd91c219531749 (patch) | |
tree | be9970aba3c7f011a7078d7a20120ff73276f709 | |
parent | 2ec22783ddf4c522df9e5fd1b2003854486d7a2b (diff) |
RADEON: refactor output init to handle multiple DVI or VGA
- refactor output init to handle multiple DVI or VGA with the new
bios table parsing
-rw-r--r-- | src/radeon_output.c | 69 |
1 files changed, 46 insertions, 23 deletions
diff --git a/src/radeon_output.c b/src/radeon_output.c index d0225aa7..0cd1183f 100644 --- a/src/radeon_output.c +++ b/src/radeon_output.c @@ -1701,7 +1701,8 @@ Bool RADEONSetupConnectors(ScrnInfoPtr pScrn) xf86OutputPtr output; char *optstr; int i = 0; - + int num_vga = 0; + int num_dvi = 0; /* We first get the information about all connectors from BIOS. * This is how the card is phyiscally wired up. @@ -1795,6 +1796,27 @@ Bool RADEONSetupConnectors(ScrnInfoPtr pScrn) for (i = 0 ; i < RADEON_MAX_BIOS_CONNECTOR; i++) { if (info->BiosConnector[i].valid) { + if (info->IsAtomBios) { + if ((info->BiosConnector[i].ConnectorType == CONNECTOR_DVI_D_ATOM) || + (info->BiosConnector[i].ConnectorType == CONNECTOR_DVI_I_ATOM) || + (info->BiosConnector[i].ConnectorType == CONNECTOR_DVI_A_ATOM)) { + num_dvi++; + } else if (info->BiosConnector[i].ConnectorType == CONNECTOR_VGA_ATOM) { + num_vga++; + } + } else { + if ((info->BiosConnector[i].ConnectorType == CONNECTOR_DVI_D) || + (info->BiosConnector[i].ConnectorType == CONNECTOR_DVI_I)) { + num_dvi++; + } else if (info->BiosConnector[i].ConnectorType == CONNECTOR_CRT) { + num_vga++; + } + } + } + } + + for (i = 0 ; i < RADEON_MAX_BIOS_CONNECTOR; i++) { + if (info->BiosConnector[i].valid) { RADEONOutputPrivatePtr radeon_output = xnfcalloc(sizeof(RADEONOutputPrivateRec), 1); if (!radeon_output) { return FALSE; @@ -1825,39 +1847,40 @@ Bool RADEONSetupConnectors(ScrnInfoPtr pScrn) } RADEONSetOutputType(pScrn, radeon_output); if (info->IsAtomBios) { - if (((info->BiosConnector[0].ConnectorType == CONNECTOR_DVI_D_ATOM) || - (info->BiosConnector[0].ConnectorType == CONNECTOR_DVI_I_ATOM) || - (info->BiosConnector[0].ConnectorType == CONNECTOR_DVI_A_ATOM)) && - ((info->BiosConnector[1].ConnectorType == CONNECTOR_DVI_D_ATOM) || - (info->BiosConnector[1].ConnectorType == CONNECTOR_DVI_I_ATOM) || - (info->BiosConnector[1].ConnectorType == CONNECTOR_DVI_A_ATOM))) { - if (i > 0) + if ((info->BiosConnector[i].ConnectorType == CONNECTOR_DVI_D_ATOM) || + (info->BiosConnector[i].ConnectorType == CONNECTOR_DVI_I_ATOM) || + (info->BiosConnector[i].ConnectorType == CONNECTOR_DVI_A_ATOM)) { + if (num_dvi > 1) { output = xf86OutputCreate(pScrn, &radeon_output_funcs, "DVI-1"); - else + num_dvi--; + } else { output = xf86OutputCreate(pScrn, &radeon_output_funcs, "DVI-0"); - } else if ((info->BiosConnector[0].ConnectorType == CONNECTOR_VGA_ATOM) && - (info->BiosConnector[1].ConnectorType == CONNECTOR_VGA_ATOM)) { - if (i > 0) + } + } else if (info->BiosConnector[0].ConnectorType == CONNECTOR_VGA_ATOM) { + if (num_vga > 1) { output = xf86OutputCreate(pScrn, &radeon_output_funcs, "VGA-1"); - else + num_vga--; + } else { output = xf86OutputCreate(pScrn, &radeon_output_funcs, "VGA-0"); + } } else output = xf86OutputCreate(pScrn, &radeon_output_funcs, OutputType[radeon_output->type]); } else { - if (((info->BiosConnector[0].ConnectorType == CONNECTOR_DVI_D) || - (info->BiosConnector[0].ConnectorType == CONNECTOR_DVI_I)) && - ((info->BiosConnector[1].ConnectorType == CONNECTOR_DVI_D) || - (info->BiosConnector[1].ConnectorType == CONNECTOR_DVI_I))) { - if (i > 0) + if ((info->BiosConnector[i].ConnectorType == CONNECTOR_DVI_D) || + (info->BiosConnector[i].ConnectorType == CONNECTOR_DVI_I)) { + if (num_dvi > 1) { output = xf86OutputCreate(pScrn, &radeon_output_funcs, "DVI-1"); - else + num_dvi--; + } else { output = xf86OutputCreate(pScrn, &radeon_output_funcs, "DVI-0"); - } else if ((info->BiosConnector[0].ConnectorType == CONNECTOR_CRT) && - (info->BiosConnector[1].ConnectorType == CONNECTOR_CRT)) { - if (i > 0) + } + } else if (info->BiosConnector[0].ConnectorType == CONNECTOR_CRT) { + if (num_vga > 1) { output = xf86OutputCreate(pScrn, &radeon_output_funcs, "VGA-1"); - else + num_vga--; + } else { output = xf86OutputCreate(pScrn, &radeon_output_funcs, "VGA-0"); + } } else output = xf86OutputCreate(pScrn, &radeon_output_funcs, OutputType[radeon_output->type]); } |