diff options
Diffstat (limited to 'sound/pci/oxygen/virtuoso.c')
-rw-r--r-- | sound/pci/oxygen/virtuoso.c | 22 |
1 files changed, 18 insertions, 4 deletions
diff --git a/sound/pci/oxygen/virtuoso.c b/sound/pci/oxygen/virtuoso.c index 1db4aa5dfad4..b678e2de4adf 100644 --- a/sound/pci/oxygen/virtuoso.c +++ b/sound/pci/oxygen/virtuoso.c | |||
@@ -47,10 +47,10 @@ | |||
47 | * GPI 0 <- external power present | 47 | * GPI 0 <- external power present |
48 | * | 48 | * |
49 | * GPIO 0 -> enable output to speakers | 49 | * GPIO 0 -> enable output to speakers |
50 | * GPIO 1 -> ALT? | 50 | * GPIO 1 -> ? |
51 | * GPIO 2 -> M0 of CS5361 | 51 | * GPIO 2 -> M0 of CS5361 |
52 | * GPIO 3 -> M1 of CS5361 | 52 | * GPIO 3 -> M1 of CS5361 |
53 | * GPIO 8 -> line-in/mic-in/digital-out switch? | 53 | * GPIO 8 -> route input jack to line-in (0) or mic-in (1) |
54 | * | 54 | * |
55 | * CS4398: | 55 | * CS4398: |
56 | * | 56 | * |
@@ -120,7 +120,7 @@ MODULE_DEVICE_TABLE(pci, xonar_ids); | |||
120 | #define GPI_DX_EXT_POWER 0x01 | 120 | #define GPI_DX_EXT_POWER 0x01 |
121 | #define GPIO_DX_OUTPUT_ENABLE 0x0001 | 121 | #define GPIO_DX_OUTPUT_ENABLE 0x0001 |
122 | #define GPIO_DX_UNKNOWN1 0x0002 | 122 | #define GPIO_DX_UNKNOWN1 0x0002 |
123 | #define GPIO_DX_UNKNOWN2 0x0100 | 123 | #define GPIO_DX_INPUT_ROUTE 0x0100 |
124 | 124 | ||
125 | #define I2C_DEVICE_CS4398 0x9e /* 10011, AD1=1, AD0=1, /W=0 */ | 125 | #define I2C_DEVICE_CS4398 0x9e /* 10011, AD1=1, AD0=1, /W=0 */ |
126 | #define I2C_DEVICE_CS4362A 0x30 /* 001100, AD0=0, /W=0 */ | 126 | #define I2C_DEVICE_CS4362A 0x30 /* 001100, AD0=0, /W=0 */ |
@@ -267,7 +267,8 @@ static void xonar_dx_init(struct oxygen *chip) | |||
267 | cs4362a_write(chip, 0x01, CS4362A_CPEN); | 267 | cs4362a_write(chip, 0x01, CS4362A_CPEN); |
268 | 268 | ||
269 | oxygen_set_bits16(chip, OXYGEN_GPIO_CONTROL, | 269 | oxygen_set_bits16(chip, OXYGEN_GPIO_CONTROL, |
270 | GPIO_DX_UNKNOWN1 | GPIO_DX_UNKNOWN2); | 270 | GPIO_DX_UNKNOWN1 | GPIO_DX_INPUT_ROUTE); |
271 | oxygen_clear_bits16(chip, OXYGEN_GPIO_DATA, GPIO_DX_INPUT_ROUTE); | ||
271 | 272 | ||
272 | xonar_common_init(chip); | 273 | xonar_common_init(chip); |
273 | 274 | ||
@@ -469,6 +470,18 @@ static const struct snd_kcontrol_new alt_switch = { | |||
469 | .put = alt_switch_put, | 470 | .put = alt_switch_put, |
470 | }; | 471 | }; |
471 | 472 | ||
473 | static void xonar_dx_ac97_switch(struct oxygen *chip, | ||
474 | unsigned int reg, unsigned int mute) | ||
475 | { | ||
476 | if (reg == AC97_LINE) { | ||
477 | spin_lock_irq(&chip->reg_lock); | ||
478 | oxygen_write16_masked(chip, OXYGEN_GPIO_DATA, | ||
479 | mute ? GPIO_DX_INPUT_ROUTE : 0, | ||
480 | GPIO_DX_INPUT_ROUTE); | ||
481 | spin_unlock_irq(&chip->reg_lock); | ||
482 | } | ||
483 | } | ||
484 | |||
472 | static const DECLARE_TLV_DB_SCALE(pcm1796_db_scale, -12000, 50, 0); | 485 | static const DECLARE_TLV_DB_SCALE(pcm1796_db_scale, -12000, 50, 0); |
473 | static const DECLARE_TLV_DB_SCALE(cs4362a_db_scale, -12700, 100, 0); | 486 | static const DECLARE_TLV_DB_SCALE(cs4362a_db_scale, -12700, 100, 0); |
474 | 487 | ||
@@ -572,6 +585,7 @@ static const struct oxygen_model xonar_models[] = { | |||
572 | .update_dac_volume = update_cs43xx_volume, | 585 | .update_dac_volume = update_cs43xx_volume, |
573 | .update_dac_mute = update_cs43xx_mute, | 586 | .update_dac_mute = update_cs43xx_mute, |
574 | .gpio_changed = xonar_gpio_changed, | 587 | .gpio_changed = xonar_gpio_changed, |
588 | .ac97_switch = xonar_dx_ac97_switch, | ||
575 | .model_data_size = sizeof(struct xonar_data), | 589 | .model_data_size = sizeof(struct xonar_data), |
576 | .pcm_dev_cfg = PLAYBACK_0_TO_I2S | | 590 | .pcm_dev_cfg = PLAYBACK_0_TO_I2S | |
577 | PLAYBACK_1_TO_SPDIF | | 591 | PLAYBACK_1_TO_SPDIF | |