diff options
author | Alex Deucher <alex@botch2.(none)> | 2007-11-06 18:04:43 -0500 |
---|---|---|
committer | Alex Deucher <alex@botch2.(none)> | 2007-11-06 18:04:43 -0500 |
commit | 20f01950e42babc308b4470df6a3c6628c932003 (patch) | |
tree | a643eff8272f6411f8161f74ced238731e66aff8 | |
parent | 78a3eabff382e8ebe33df2039076fb083bcc361b (diff) |
for r4xx ATOM cards, just use ATOM for PLL
while crtc timing and pll seem to work fine, output setup
and routing don't seem to work too reliably with atom.
AMD claims ATOM was still pretty new with r4xx so
it's probably better to stick with direct programming for
some things.
-rw-r--r-- | src/radeon_crtc.c | 43 | ||||
-rw-r--r-- | src/radeon_output.c | 7 |
2 files changed, 16 insertions, 34 deletions
diff --git a/src/radeon_crtc.c b/src/radeon_crtc.c index 55307136..4a017c04 100644 --- a/src/radeon_crtc.c +++ b/src/radeon_crtc.c @@ -70,10 +70,10 @@ radeon_crtc_dpms(xf86CrtcPtr crtc, int mode) RADEONInfoPtr info = RADEONPTR(pScrn); unsigned char *RADEONMMIO = info->MMIO; -#if 1 +#if 0 if (info->IsAtomBios) { atombios_crtc_dpms(crtc, mode); - //return; + return; } #endif @@ -132,12 +132,7 @@ radeon_crtc_mode_prepare(xf86CrtcPtr crtc) ScrnInfoPtr pScrn = crtc->scrn; RADEONInfoPtr info = RADEONPTR(pScrn); -#if 1 - if (info->IsAtomBios) - atombios_crtc_dpms(crtc, DPMSModeOff); - else -#endif - radeon_crtc_dpms(crtc, DPMSModeOff); + radeon_crtc_dpms(crtc, DPMSModeOff); } /* Define common registers for requested video mode */ @@ -916,26 +911,24 @@ radeon_crtc_mode_set(xf86CrtcPtr crtc, DisplayModePtr mode, ErrorF("restore common\n"); RADEONRestoreCommonRegisters(pScrn, &info->ModeReg); -#if 1 - if (info->IsAtomBios) { - //RADEONRestoreCrtcRegisters(pScrn, &info->ModeReg); - atombios_crtc_mode_set(crtc, mode, adjusted_mode, x, y); - return; - } -#endif - switch (radeon_crtc->crtc_id) { case 0: ErrorF("restore crtc1\n"); RADEONRestoreCrtcRegisters(pScrn, &info->ModeReg); ErrorF("restore pll1\n"); - RADEONRestorePLLRegisters(pScrn, &info->ModeReg); + if (info->IsAtomBios) + atombios_crtc_set_pll(crtc, adjusted_mode); + else + RADEONRestorePLLRegisters(pScrn, &info->ModeReg); break; case 1: ErrorF("restore crtc2\n"); RADEONRestoreCrtc2Registers(pScrn, &info->ModeReg); ErrorF("restore pll2\n"); - RADEONRestorePLL2Registers(pScrn, &info->ModeReg); + if (info->IsAtomBios) + atombios_crtc_set_pll(crtc, adjusted_mode); + else + RADEONRestorePLL2Registers(pScrn, &info->ModeReg); break; } @@ -960,13 +953,6 @@ radeon_crtc_mode_set(xf86CrtcPtr crtc, DisplayModePtr mode, /* reset ecp_div for Xv */ info->ecp_div = -1; -#if 0 - if (info->IsAtomBios) { - atombios_crtc_mode_set(crtc, mode, adjusted_mode, x, y); - //return; - } -#endif - } static void @@ -975,12 +961,7 @@ radeon_crtc_mode_commit(xf86CrtcPtr crtc) ScrnInfoPtr pScrn = crtc->scrn; RADEONInfoPtr info = RADEONPTR(pScrn); -#if 1 - if (info->IsAtomBios) - atombios_crtc_dpms(crtc, DPMSModeOn); - //else -#endif - radeon_crtc_dpms(crtc, DPMSModeOn); + radeon_crtc_dpms(crtc, DPMSModeOn); } void radeon_crtc_load_lut(xf86CrtcPtr crtc) diff --git a/src/radeon_output.c b/src/radeon_output.c index d00908b9..be542a4a 100644 --- a/src/radeon_output.c +++ b/src/radeon_output.c @@ -160,6 +160,7 @@ extern void atombios_output_mode_set(xf86OutputPtr output, DisplayModePtr adjusted_mode); extern void atombios_output_dpms(xf86OutputPtr output, int mode); #endif + Bool RADEONDVOReadByte(I2CDevPtr dvo, int addr, CARD8 *ch) { @@ -714,7 +715,7 @@ radeon_dpms(xf86OutputPtr output, int mode) ScrnInfoPtr pScrn = output->scrn; RADEONInfoPtr info = RADEONPTR(pScrn); -#if 1 +#if 0 if (info->IsAtomBios) { atombios_output_dpms(output, mode); return; @@ -1224,10 +1225,10 @@ radeon_mode_commit(xf86OutputPtr output) { ScrnInfoPtr pScrn = output->scrn; RADEONInfoPtr info = RADEONPTR(pScrn); -#if 1 +#if 0 if (info->IsAtomBios) atombios_output_dpms(output, DPMSModeOn); - //else + else #endif RADEONEnableDisplay(output, TRUE); } |