From 20f01950e42babc308b4470df6a3c6628c932003 Mon Sep 17 00:00:00 2001 From: Alex Deucher Date: Tue, 6 Nov 2007 18:04:43 -0500 Subject: 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. --- src/radeon_crtc.c | 43 ++++++++++++------------------------------- 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); } -- cgit v1.2.3