summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/radeon_output.c109
-rw-r--r--src/radeon_reg.h1
2 files changed, 40 insertions, 70 deletions
diff --git a/src/radeon_output.c b/src/radeon_output.c
index ccbc3063..e61b9781 100644
--- a/src/radeon_output.c
+++ b/src/radeon_output.c
@@ -154,7 +154,7 @@ static RADEONMonitorType radeon_detect_primary_dac(ScrnInfoPtr pScrn, Bool color
static RADEONMonitorType radeon_detect_tv_dac(ScrnInfoPtr pScrn, Bool color);
static RADEONMonitorType radeon_detect_ext_dac(ScrnInfoPtr pScrn);
static void RADEONGetTMDSInfoFromTable(xf86OutputPtr output);
-static Bool AVIVOI2CDoLock(ScrnInfoPtr pScrn, int lock_state);
+static Bool AVIVOI2CDoLock(ScrnInfoPtr pScrn, int lock_state, int gpio);
extern void atombios_output_mode_set(xf86OutputPtr output,
DisplayModePtr mode,
@@ -283,9 +283,9 @@ avivo_display_ddc_connected(ScrnInfoPtr pScrn, xf86OutputPtr output)
RADEONDDCType DDCType = radeon_output->DDCType;
if (radeon_output->pI2CBus) {
- AVIVOI2CDoLock(output->scrn, 1);
+ AVIVOI2CDoLock(output->scrn, 1, radeon_output->gpio);
MonInfo = xf86OutputGetEDID(output, radeon_output->pI2CBus);
- AVIVOI2CDoLock(output->scrn, 0);
+ AVIVOI2CDoLock(output->scrn, 0, radeon_output->gpio);
}
if (MonInfo) {
if (!xf86ReturnOptValBool(info->Options, OPTION_IGNORE_EDID, FALSE))
@@ -2307,52 +2307,52 @@ Bool AVIVOI2CReset(ScrnInfoPtr pScrn)
}
static
-Bool AVIVOI2CDoLock(ScrnInfoPtr pScrn, int lock_state)
+Bool AVIVOI2CDoLock(ScrnInfoPtr pScrn, int lock_state, int gpio_reg)
{
RADEONInfoPtr info = RADEONPTR(pScrn);
unsigned char *RADEONMMIO = info->MMIO;
CARD32 temp;
- switch(lock_state) {
- case 0:
- temp = INREG(AVIVO_I2C_CNTL);
- OUTREG(AVIVO_I2C_CNTL, temp | 0x100);
- /* enable hdcp block */
- OUTREG(R520_PCLK_HDCP_CNTL, 0x0);
- break;
- case 1:
- /* disable hdcp block */
- OUTREG(R520_PCLK_HDCP_CNTL, 0x1);
- usleep(1);
- OUTREG(AVIVO_I2C_CNTL, 0x1);
- usleep(1);
- temp = INREG(AVIVO_I2C_CNTL);
- if (!(temp & 0x2)) {
- ErrorF("Lock failed %08X\n", temp);
- return FALSE;
- }
- break;
+ temp = INREG(gpio_reg + 4);
+ if (gpio_reg == AVIVO_GPIO_0) {
+ if (lock_state == 0)
+ temp |= (1 << 19) | (1 << 18);
+ else
+ temp &= ~((1 << 19) | (1 << 18));
+ } else {
+ if (lock_state == 0)
+ temp |= (1 << 0) | (1 << 8);
+ else
+ temp &= ~((1 << 0) | (1 << 8));
}
+ OUTREG(gpio_reg + 4, temp);
+ temp = INREG(gpio_reg + 4);
+
return TRUE;
}
void
-avivo_i2c_gpio0_get_bits(I2CBusPtr b, int *Clock, int *data)
+avivo_i2c_gpio_get_bits(I2CBusPtr b, int *Clock, int *data)
{
ScrnInfoPtr screen_info = xf86Screens[b->scrnIndex];
RADEONInfoPtr info = RADEONPTR(screen_info);
unsigned char *RADEONMMIO = info->MMIO;
unsigned long val;
- ErrorF("INREG %08x\n", INREG(b->DriverPrivate.uval));
/* Get the result */
- val = INREG(b->DriverPrivate.uval + 0xC);
- *Clock = (val & (1<<19)) != 0;
- *data = (val & (1<<18)) != 0;
+ if (b->DriverPrivate.uval == AVIVO_GPIO_0) {
+ val = INREG(b->DriverPrivate.uval + 0xc);
+ *Clock = (val & (1<<19)) != 0;
+ *data = (val & (1<<18)) != 0;
+ } else {
+ val = INREG(b->DriverPrivate.uval + 0xc);
+ *Clock = (val & (1<<0)) != 0;
+ *data = (val & (1<<8)) != 0;
+ }
}
-void
-avivo_i2c_gpio0_put_bits(I2CBusPtr b, int Clock, int data)
+static void
+avivo_i2c_gpio_put_bits(I2CBusPtr b, int Clock, int data)
{
ScrnInfoPtr screen_info = xf86Screens[b->scrnIndex];
RADEONInfoPtr info = RADEONPTR(screen_info);
@@ -2360,41 +2360,15 @@ avivo_i2c_gpio0_put_bits(I2CBusPtr b, int Clock, int data)
unsigned long val;
val = 0;
- val |= (Clock ? 0:(1<<19));
- val |= (data ? 0:(1<<18));
- OUTREG(b->DriverPrivate.uval + 0x8, val);
- /* read back to improve reliability on some cards. */
- val = INREG(b->DriverPrivate.uval + 0x8);
-}
-
-void
-avivo_i2c_gpio123_get_bits(I2CBusPtr b, int *Clock, int *data)
-{
- ScrnInfoPtr screen_info = xf86Screens[b->scrnIndex];
- RADEONInfoPtr info = RADEONPTR(screen_info);
- unsigned char *RADEONMMIO = info->MMIO;
- unsigned long val;
-
- if (INREG(b->DriverPrivate.uval) == 0)
- OUTREG(b->DriverPrivate.uval, (1<<0) | (1<<8));
-
- /* Get the result */
- val = INREG(b->DriverPrivate.uval + 0xC);
- *Clock = (val & (1<<0)) != 0;
- *data = (val & (1<<8)) != 0;
-}
+ if (b->DriverPrivate.uval == AVIVO_GPIO_0) {
+ val |= (Clock ? 0:(1<<19));
+ val |= (data ? 0:(1<<18));
+ } else {
+ val |= (Clock ? 0:(1<<0));
+ val |= (data ? 0:(1<<8));
-static void
-avivo_i2c_gpio123_put_bits(I2CBusPtr b, int Clock, int data)
-{
- ScrnInfoPtr screen_info = xf86Screens[b->scrnIndex];
- RADEONInfoPtr info = RADEONPTR(screen_info);
- unsigned char *RADEONMMIO = info->MMIO;
- unsigned long val;
+ }
- val = 0;
- val |= (Clock ? 0:(1<<0));
- val |= (data ? 0:(1<<8));
OUTREG(b->DriverPrivate.uval + 0x8, val);
/* read back to improve reliability on some cards. */
val = INREG(b->DriverPrivate.uval + 0x8);
@@ -2410,13 +2384,8 @@ avivo_i2c_init(ScrnInfoPtr pScrn, I2CBusPtr *bus_ptr, int i2c_reg, char *name)
pI2CBus->BusName = name;
pI2CBus->scrnIndex = pScrn->scrnIndex;
- if (i2c_reg == AVIVO_GPIO_0) {
- pI2CBus->I2CPutBits = avivo_i2c_gpio0_put_bits;
- pI2CBus->I2CGetBits = avivo_i2c_gpio0_get_bits;
- } else {
- pI2CBus->I2CPutBits = avivo_i2c_gpio123_put_bits;
- pI2CBus->I2CGetBits = avivo_i2c_gpio123_get_bits;
- }
+ pI2CBus->I2CPutBits = avivo_i2c_gpio_put_bits;
+ pI2CBus->I2CGetBits = avivo_i2c_gpio_get_bits;
pI2CBus->AcknTimeout = 5;
pI2CBus->DriverPrivate.uval = i2c_reg;
diff --git a/src/radeon_reg.h b/src/radeon_reg.h
index e299481a..290869fa 100644
--- a/src/radeon_reg.h
+++ b/src/radeon_reg.h
@@ -3646,6 +3646,7 @@
#define AVIVO_GPIO_2 0x7e50
#define AVIVO_GPIO_3 0x7e60
+#define AVIVO_DC_GPIO_HPD_Y 0x7e9c
#define R520_PCLK_HDCP_CNTL 0x494
#define AVIVO_I2C_STATUS 0x7d30