summaryrefslogtreecommitdiff
path: root/src/atombios_output.c
diff options
context:
space:
mode:
authorAlex Deucher <alexdeucher@gmail.com>2008-12-17 04:54:50 -0500
committerAlex Deucher <alexdeucher@gmail.com>2008-12-17 04:54:50 -0500
commit6ed0e68060fd2775e2d4027ff1533729e87848ba (patch)
treea0f2ce2dad11cfb8a2f2e010fb5f733835588b52 /src/atombios_output.c
parentf21e673aced1bb5138bbb80e6d9724530eb95ebf (diff)
properly handle EnableYUV
A bit of a hack. we really need to restructure the bios scratch reg handling.
Diffstat (limited to 'src/atombios_output.c')
-rw-r--r--src/atombios_output.c35
1 files changed, 20 insertions, 15 deletions
diff --git a/src/atombios_output.c b/src/atombios_output.c
index 6603b102..a687beab 100644
--- a/src/atombios_output.c
+++ b/src/atombios_output.c
@@ -833,26 +833,29 @@ static void atom_rv515_force_tv_scaler(ScrnInfoPtr pScrn)
OUTREG(0x657C,0xBF008900);
}
-static void atom_enable_yuv_transform(xf86OutputPtr output, Bool enable)
-{
- RADEONCrtcPrivatePtr radeon_crtc = output->crtc->driver_private;
- RADEONInfoPtr info = RADEONPTR(output->scrn);
- unsigned char *RADEONMMIO = info->MMIO;
-
- if (enable)
- OUTREG(AVIVO_D1GRPH_COLOR_MATRIX_TRANSFORMATION_CNTL + radeon_crtc->crtc_offset, 0x1);
- else
- OUTREG(AVIVO_D1GRPH_COLOR_MATRIX_TRANSFORMATION_CNTL + radeon_crtc->crtc_offset, 0x0);
-}
-
static int
atombios_output_yuv_setup(xf86OutputPtr output, Bool enable)
{
+ RADEONOutputPrivatePtr radeon_output = output->driver_private;
RADEONInfoPtr info = RADEONPTR(output->scrn);
RADEONCrtcPrivatePtr radeon_crtc = output->crtc->driver_private;
ENABLE_YUV_PS_ALLOCATION disp_data;
AtomBiosArgRec data;
unsigned char *space;
+ unsigned char *RADEONMMIO = info->MMIO;
+ uint32_t temp;
+
+ //fix up scratch reg handling
+ temp = INREG(R600_BIOS_3_SCRATCH);
+ if ((radeon_output->MonType == MT_CTV) ||
+ (radeon_output->MonType == MT_STV))
+ OUTREG(R600_BIOS_3_SCRATCH, (ATOM_S3_TV1_ACTIVE |
+ (radeon_crtc->crtc_id << 18)));
+ else if (radeon_output->MonType == MT_CV)
+ OUTREG(R600_BIOS_3_SCRATCH, (ATOM_S3_CV_ACTIVE |
+ (radeon_crtc->crtc_id << 24)));
+ else
+ OUTREG(R600_BIOS_3_SCRATCH, 0);
memset(&disp_data, 0, sizeof(disp_data));
@@ -866,13 +869,15 @@ atombios_output_yuv_setup(xf86OutputPtr output, Bool enable)
if (RHDAtomBiosFunc(info->atomBIOS->scrnIndex, info->atomBIOS, ATOMBIOS_EXEC, &data) == ATOM_SUCCESS) {
- atom_enable_yuv_transform(output, enable);
+ OUTREG(R600_BIOS_3_SCRATCH, temp);
- ErrorF("YUV %d setup success\n", radeon_crtc->crtc_id);
+ ErrorF("crtc %d YUV %s setup success\n", radeon_crtc->crtc_id, enable ? "enable" : "disable");
return ATOM_SUCCESS;
}
- ErrorF("YUV %d setup failed\n", radeon_crtc->crtc_id);
+ OUTREG(R600_BIOS_3_SCRATCH, temp);
+
+ ErrorF("crtc %d YUV %s setup failed\n", radeon_crtc->crtc_id, enable ? "enable" : "disable");
return ATOM_NOT_IMPLEMENTED;
}