diff options
Diffstat (limited to 'sound')
-rw-r--r-- | sound/pci/Kconfig | 2 | ||||
-rw-r--r-- | sound/pci/hda/patch_realtek.c | 45 | ||||
-rw-r--r-- | sound/pci/oxygen/virtuoso.c | 73 | ||||
-rw-r--r-- | sound/soc/codecs/wm8990.c | 10 | ||||
-rw-r--r-- | sound/soc/codecs/wm8990.h | 14 |
5 files changed, 120 insertions, 24 deletions
diff --git a/sound/pci/Kconfig b/sound/pci/Kconfig index f7d95b224a98..31f52d3fc21f 100644 --- a/sound/pci/Kconfig +++ b/sound/pci/Kconfig | |||
@@ -845,7 +845,7 @@ config SND_VIRTUOSO | |||
845 | select SND_OXYGEN_LIB | 845 | select SND_OXYGEN_LIB |
846 | help | 846 | help |
847 | Say Y here to include support for sound cards based on the | 847 | Say Y here to include support for sound cards based on the |
848 | Asus AV100/AV200 chips, i.e., Xonar D2, DX and D2X. | 848 | Asus AV100/AV200 chips, i.e., Xonar D1, DX, D2 and D2X. |
849 | 849 | ||
850 | To compile this driver as a module, choose M here: the module | 850 | To compile this driver as a module, choose M here: the module |
851 | will be called snd-virtuoso. | 851 | will be called snd-virtuoso. |
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index add4e87e0b20..b80e725432f0 100644 --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c | |||
@@ -6437,6 +6437,39 @@ static void alc882_auto_init_analog_input(struct hda_codec *codec) | |||
6437 | } | 6437 | } |
6438 | } | 6438 | } |
6439 | 6439 | ||
6440 | static void alc882_auto_init_input_src(struct hda_codec *codec) | ||
6441 | { | ||
6442 | struct alc_spec *spec = codec->spec; | ||
6443 | const struct hda_input_mux *imux = spec->input_mux; | ||
6444 | int c; | ||
6445 | |||
6446 | for (c = 0; c < spec->num_adc_nids; c++) { | ||
6447 | hda_nid_t conn_list[HDA_MAX_NUM_INPUTS]; | ||
6448 | hda_nid_t nid = spec->capsrc_nids[c]; | ||
6449 | int conns, mute, idx, item; | ||
6450 | |||
6451 | conns = snd_hda_get_connections(codec, nid, conn_list, | ||
6452 | ARRAY_SIZE(conn_list)); | ||
6453 | if (conns < 0) | ||
6454 | continue; | ||
6455 | for (idx = 0; idx < conns; idx++) { | ||
6456 | /* if the current connection is the selected one, | ||
6457 | * unmute it as default - otherwise mute it | ||
6458 | */ | ||
6459 | mute = AMP_IN_MUTE(idx); | ||
6460 | for (item = 0; item < imux->num_items; item++) { | ||
6461 | if (imux->items[item].index == idx) { | ||
6462 | if (spec->cur_mux[c] == item) | ||
6463 | mute = AMP_IN_UNMUTE(idx); | ||
6464 | break; | ||
6465 | } | ||
6466 | } | ||
6467 | snd_hda_codec_write(codec, nid, 0, | ||
6468 | AC_VERB_SET_AMP_GAIN_MUTE, mute); | ||
6469 | } | ||
6470 | } | ||
6471 | } | ||
6472 | |||
6440 | /* add mic boosts if needed */ | 6473 | /* add mic boosts if needed */ |
6441 | static int alc_auto_add_mic_boost(struct hda_codec *codec) | 6474 | static int alc_auto_add_mic_boost(struct hda_codec *codec) |
6442 | { | 6475 | { |
@@ -6491,6 +6524,7 @@ static void alc882_auto_init(struct hda_codec *codec) | |||
6491 | alc882_auto_init_multi_out(codec); | 6524 | alc882_auto_init_multi_out(codec); |
6492 | alc882_auto_init_hp_out(codec); | 6525 | alc882_auto_init_hp_out(codec); |
6493 | alc882_auto_init_analog_input(codec); | 6526 | alc882_auto_init_analog_input(codec); |
6527 | alc882_auto_init_input_src(codec); | ||
6494 | if (spec->unsol_event) | 6528 | if (spec->unsol_event) |
6495 | alc_sku_automute(codec); | 6529 | alc_sku_automute(codec); |
6496 | } | 6530 | } |
@@ -8285,6 +8319,8 @@ static void alc883_auto_init_analog_input(struct hda_codec *codec) | |||
8285 | } | 8319 | } |
8286 | } | 8320 | } |
8287 | 8321 | ||
8322 | #define alc883_auto_init_input_src alc882_auto_init_input_src | ||
8323 | |||
8288 | /* almost identical with ALC880 parser... */ | 8324 | /* almost identical with ALC880 parser... */ |
8289 | static int alc883_parse_auto_config(struct hda_codec *codec) | 8325 | static int alc883_parse_auto_config(struct hda_codec *codec) |
8290 | { | 8326 | { |
@@ -8315,6 +8351,7 @@ static void alc883_auto_init(struct hda_codec *codec) | |||
8315 | alc883_auto_init_multi_out(codec); | 8351 | alc883_auto_init_multi_out(codec); |
8316 | alc883_auto_init_hp_out(codec); | 8352 | alc883_auto_init_hp_out(codec); |
8317 | alc883_auto_init_analog_input(codec); | 8353 | alc883_auto_init_analog_input(codec); |
8354 | alc883_auto_init_input_src(codec); | ||
8318 | if (spec->unsol_event) | 8355 | if (spec->unsol_event) |
8319 | alc_sku_automute(codec); | 8356 | alc_sku_automute(codec); |
8320 | } | 8357 | } |
@@ -9663,6 +9700,7 @@ static int alc262_parse_auto_config(struct hda_codec *codec) | |||
9663 | #define alc262_auto_init_multi_out alc882_auto_init_multi_out | 9700 | #define alc262_auto_init_multi_out alc882_auto_init_multi_out |
9664 | #define alc262_auto_init_hp_out alc882_auto_init_hp_out | 9701 | #define alc262_auto_init_hp_out alc882_auto_init_hp_out |
9665 | #define alc262_auto_init_analog_input alc882_auto_init_analog_input | 9702 | #define alc262_auto_init_analog_input alc882_auto_init_analog_input |
9703 | #define alc262_auto_init_input_src alc882_auto_init_input_src | ||
9666 | 9704 | ||
9667 | 9705 | ||
9668 | /* init callback for auto-configuration model -- overriding the default init */ | 9706 | /* init callback for auto-configuration model -- overriding the default init */ |
@@ -9672,6 +9710,7 @@ static void alc262_auto_init(struct hda_codec *codec) | |||
9672 | alc262_auto_init_multi_out(codec); | 9710 | alc262_auto_init_multi_out(codec); |
9673 | alc262_auto_init_hp_out(codec); | 9711 | alc262_auto_init_hp_out(codec); |
9674 | alc262_auto_init_analog_input(codec); | 9712 | alc262_auto_init_analog_input(codec); |
9713 | alc262_auto_init_input_src(codec); | ||
9675 | if (spec->unsol_event) | 9714 | if (spec->unsol_event) |
9676 | alc_sku_automute(codec); | 9715 | alc_sku_automute(codec); |
9677 | } | 9716 | } |
@@ -13330,6 +13369,8 @@ static void alc861vd_auto_init_analog_input(struct hda_codec *codec) | |||
13330 | } | 13369 | } |
13331 | } | 13370 | } |
13332 | 13371 | ||
13372 | #define alc861vd_auto_init_input_src alc882_auto_init_input_src | ||
13373 | |||
13333 | #define alc861vd_idx_to_mixer_vol(nid) ((nid) + 0x02) | 13374 | #define alc861vd_idx_to_mixer_vol(nid) ((nid) + 0x02) |
13334 | #define alc861vd_idx_to_mixer_switch(nid) ((nid) + 0x0c) | 13375 | #define alc861vd_idx_to_mixer_switch(nid) ((nid) + 0x0c) |
13335 | 13376 | ||
@@ -13512,6 +13553,7 @@ static void alc861vd_auto_init(struct hda_codec *codec) | |||
13512 | alc861vd_auto_init_multi_out(codec); | 13553 | alc861vd_auto_init_multi_out(codec); |
13513 | alc861vd_auto_init_hp_out(codec); | 13554 | alc861vd_auto_init_hp_out(codec); |
13514 | alc861vd_auto_init_analog_input(codec); | 13555 | alc861vd_auto_init_analog_input(codec); |
13556 | alc861vd_auto_init_input_src(codec); | ||
13515 | if (spec->unsol_event) | 13557 | if (spec->unsol_event) |
13516 | alc_sku_automute(codec); | 13558 | alc_sku_automute(codec); |
13517 | } | 13559 | } |
@@ -14677,6 +14719,8 @@ static void alc662_auto_init_analog_input(struct hda_codec *codec) | |||
14677 | } | 14719 | } |
14678 | } | 14720 | } |
14679 | 14721 | ||
14722 | #define alc662_auto_init_input_src alc882_auto_init_input_src | ||
14723 | |||
14680 | static int alc662_parse_auto_config(struct hda_codec *codec) | 14724 | static int alc662_parse_auto_config(struct hda_codec *codec) |
14681 | { | 14725 | { |
14682 | struct alc_spec *spec = codec->spec; | 14726 | struct alc_spec *spec = codec->spec; |
@@ -14733,6 +14777,7 @@ static void alc662_auto_init(struct hda_codec *codec) | |||
14733 | alc662_auto_init_multi_out(codec); | 14777 | alc662_auto_init_multi_out(codec); |
14734 | alc662_auto_init_hp_out(codec); | 14778 | alc662_auto_init_hp_out(codec); |
14735 | alc662_auto_init_analog_input(codec); | 14779 | alc662_auto_init_analog_input(codec); |
14780 | alc662_auto_init_input_src(codec); | ||
14736 | if (spec->unsol_event) | 14781 | if (spec->unsol_event) |
14737 | alc_sku_automute(codec); | 14782 | alc_sku_automute(codec); |
14738 | } | 14783 | } |
diff --git a/sound/pci/oxygen/virtuoso.c b/sound/pci/oxygen/virtuoso.c index 9a2c16bf94e0..01d7b75f9182 100644 --- a/sound/pci/oxygen/virtuoso.c +++ b/sound/pci/oxygen/virtuoso.c | |||
@@ -36,15 +36,15 @@ | |||
36 | */ | 36 | */ |
37 | 37 | ||
38 | /* | 38 | /* |
39 | * Xonar DX | 39 | * Xonar D1/DX |
40 | * -------- | 40 | * ----------- |
41 | * | 41 | * |
42 | * CMI8788: | 42 | * CMI8788: |
43 | * | 43 | * |
44 | * I²C <-> CS4398 (front) | 44 | * I²C <-> CS4398 (front) |
45 | * <-> CS4362A (surround, center/LFE, back) | 45 | * <-> CS4362A (surround, center/LFE, back) |
46 | * | 46 | * |
47 | * GPI 0 <- external power present | 47 | * GPI 0 <- external power present (DX only) |
48 | * | 48 | * |
49 | * GPIO 0 -> enable output to speakers | 49 | * GPIO 0 -> enable output to speakers |
50 | * GPIO 1 -> enable front panel I/O | 50 | * GPIO 1 -> enable front panel I/O |
@@ -96,6 +96,7 @@ MODULE_PARM_DESC(enable, "enable card"); | |||
96 | enum { | 96 | enum { |
97 | MODEL_D2, | 97 | MODEL_D2, |
98 | MODEL_D2X, | 98 | MODEL_D2X, |
99 | MODEL_D1, | ||
99 | MODEL_DX, | 100 | MODEL_DX, |
100 | }; | 101 | }; |
101 | 102 | ||
@@ -103,6 +104,7 @@ static struct pci_device_id xonar_ids[] __devinitdata = { | |||
103 | { OXYGEN_PCI_SUBID(0x1043, 0x8269), .driver_data = MODEL_D2 }, | 104 | { OXYGEN_PCI_SUBID(0x1043, 0x8269), .driver_data = MODEL_D2 }, |
104 | { OXYGEN_PCI_SUBID(0x1043, 0x8275), .driver_data = MODEL_DX }, | 105 | { OXYGEN_PCI_SUBID(0x1043, 0x8275), .driver_data = MODEL_DX }, |
105 | { OXYGEN_PCI_SUBID(0x1043, 0x82b7), .driver_data = MODEL_D2X }, | 106 | { OXYGEN_PCI_SUBID(0x1043, 0x82b7), .driver_data = MODEL_D2X }, |
107 | { OXYGEN_PCI_SUBID(0x1043, 0x834f), .driver_data = MODEL_D1 }, | ||
106 | { } | 108 | { } |
107 | }; | 109 | }; |
108 | MODULE_DEVICE_TABLE(pci, xonar_ids); | 110 | MODULE_DEVICE_TABLE(pci, xonar_ids); |
@@ -313,15 +315,12 @@ static void cs43xx_init(struct oxygen *chip) | |||
313 | cs4362a_write(chip, 0x01, CS4362A_CPEN); | 315 | cs4362a_write(chip, 0x01, CS4362A_CPEN); |
314 | } | 316 | } |
315 | 317 | ||
316 | static void xonar_dx_init(struct oxygen *chip) | 318 | static void xonar_d1_init(struct oxygen *chip) |
317 | { | 319 | { |
318 | struct xonar_data *data = chip->model_data; | 320 | struct xonar_data *data = chip->model_data; |
319 | 321 | ||
320 | data->anti_pop_delay = 800; | 322 | data->anti_pop_delay = 800; |
321 | data->output_enable_bit = GPIO_DX_OUTPUT_ENABLE; | 323 | data->output_enable_bit = GPIO_DX_OUTPUT_ENABLE; |
322 | data->ext_power_reg = OXYGEN_GPI_DATA; | ||
323 | data->ext_power_int_reg = OXYGEN_GPI_INTERRUPT_MASK; | ||
324 | data->ext_power_bit = GPI_DX_EXT_POWER; | ||
325 | data->cs4398_fm = CS4398_FM_SINGLE | CS4398_DEM_NONE | CS4398_DIF_LJUST; | 324 | data->cs4398_fm = CS4398_FM_SINGLE | CS4398_DEM_NONE | CS4398_DIF_LJUST; |
326 | data->cs4362a_fm = CS4362A_FM_SINGLE | | 325 | data->cs4362a_fm = CS4362A_FM_SINGLE | |
327 | CS4362A_ATAPI_B_R | CS4362A_ATAPI_A_L; | 326 | CS4362A_ATAPI_B_R | CS4362A_ATAPI_A_L; |
@@ -345,6 +344,16 @@ static void xonar_dx_init(struct oxygen *chip) | |||
345 | snd_component_add(chip->card, "CS5361"); | 344 | snd_component_add(chip->card, "CS5361"); |
346 | } | 345 | } |
347 | 346 | ||
347 | static void xonar_dx_init(struct oxygen *chip) | ||
348 | { | ||
349 | struct xonar_data *data = chip->model_data; | ||
350 | |||
351 | data->ext_power_reg = OXYGEN_GPI_DATA; | ||
352 | data->ext_power_int_reg = OXYGEN_GPI_INTERRUPT_MASK; | ||
353 | data->ext_power_bit = GPI_DX_EXT_POWER; | ||
354 | xonar_d1_init(chip); | ||
355 | } | ||
356 | |||
348 | static void xonar_cleanup(struct oxygen *chip) | 357 | static void xonar_cleanup(struct oxygen *chip) |
349 | { | 358 | { |
350 | struct xonar_data *data = chip->model_data; | 359 | struct xonar_data *data = chip->model_data; |
@@ -352,7 +361,7 @@ static void xonar_cleanup(struct oxygen *chip) | |||
352 | oxygen_clear_bits16(chip, OXYGEN_GPIO_DATA, data->output_enable_bit); | 361 | oxygen_clear_bits16(chip, OXYGEN_GPIO_DATA, data->output_enable_bit); |
353 | } | 362 | } |
354 | 363 | ||
355 | static void xonar_dx_cleanup(struct oxygen *chip) | 364 | static void xonar_d1_cleanup(struct oxygen *chip) |
356 | { | 365 | { |
357 | xonar_cleanup(chip); | 366 | xonar_cleanup(chip); |
358 | cs4362a_write(chip, 0x01, CS4362A_PDN | CS4362A_CPEN); | 367 | cs4362a_write(chip, 0x01, CS4362A_PDN | CS4362A_CPEN); |
@@ -365,7 +374,7 @@ static void xonar_d2_resume(struct oxygen *chip) | |||
365 | xonar_enable_output(chip); | 374 | xonar_enable_output(chip); |
366 | } | 375 | } |
367 | 376 | ||
368 | static void xonar_dx_resume(struct oxygen *chip) | 377 | static void xonar_d1_resume(struct oxygen *chip) |
369 | { | 378 | { |
370 | cs43xx_init(chip); | 379 | cs43xx_init(chip); |
371 | xonar_enable_output(chip); | 380 | xonar_enable_output(chip); |
@@ -513,7 +522,7 @@ static const struct snd_kcontrol_new front_panel_switch = { | |||
513 | .put = front_panel_put, | 522 | .put = front_panel_put, |
514 | }; | 523 | }; |
515 | 524 | ||
516 | static void xonar_dx_ac97_switch(struct oxygen *chip, | 525 | static void xonar_d1_ac97_switch(struct oxygen *chip, |
517 | unsigned int reg, unsigned int mute) | 526 | unsigned int reg, unsigned int mute) |
518 | { | 527 | { |
519 | if (reg == AC97_LINE) { | 528 | if (reg == AC97_LINE) { |
@@ -536,7 +545,7 @@ static int xonar_d2_control_filter(struct snd_kcontrol_new *template) | |||
536 | return 0; | 545 | return 0; |
537 | } | 546 | } |
538 | 547 | ||
539 | static int xonar_dx_control_filter(struct snd_kcontrol_new *template) | 548 | static int xonar_d1_control_filter(struct snd_kcontrol_new *template) |
540 | { | 549 | { |
541 | if (!strncmp(template->name, "CD Capture ", 11)) | 550 | if (!strncmp(template->name, "CD Capture ", 11)) |
542 | return 1; /* no CD input */ | 551 | return 1; /* no CD input */ |
@@ -548,7 +557,7 @@ static int xonar_mixer_init(struct oxygen *chip) | |||
548 | return snd_ctl_add(chip->card, snd_ctl_new1(&alt_switch, chip)); | 557 | return snd_ctl_add(chip->card, snd_ctl_new1(&alt_switch, chip)); |
549 | } | 558 | } |
550 | 559 | ||
551 | static int xonar_dx_mixer_init(struct oxygen *chip) | 560 | static int xonar_d1_mixer_init(struct oxygen *chip) |
552 | { | 561 | { |
553 | return snd_ctl_add(chip->card, snd_ctl_new1(&front_panel_switch, chip)); | 562 | return snd_ctl_add(chip->card, snd_ctl_new1(&front_panel_switch, chip)); |
554 | } | 563 | } |
@@ -615,23 +624,51 @@ static const struct oxygen_model xonar_models[] = { | |||
615 | .dac_i2s_format = OXYGEN_I2S_FORMAT_LJUST, | 624 | .dac_i2s_format = OXYGEN_I2S_FORMAT_LJUST, |
616 | .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST, | 625 | .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST, |
617 | }, | 626 | }, |
627 | [MODEL_D1] = { | ||
628 | .shortname = "Xonar D1", | ||
629 | .longname = "Asus Virtuoso 100", | ||
630 | .chip = "AV200", | ||
631 | .owner = THIS_MODULE, | ||
632 | .init = xonar_d1_init, | ||
633 | .control_filter = xonar_d1_control_filter, | ||
634 | .mixer_init = xonar_d1_mixer_init, | ||
635 | .cleanup = xonar_d1_cleanup, | ||
636 | .suspend = xonar_d1_cleanup, | ||
637 | .resume = xonar_d1_resume, | ||
638 | .set_dac_params = set_cs43xx_params, | ||
639 | .set_adc_params = set_cs53x1_params, | ||
640 | .update_dac_volume = update_cs43xx_volume, | ||
641 | .update_dac_mute = update_cs43xx_mute, | ||
642 | .ac97_switch = xonar_d1_ac97_switch, | ||
643 | .dac_tlv = cs4362a_db_scale, | ||
644 | .model_data_size = sizeof(struct xonar_data), | ||
645 | .pcm_dev_cfg = PLAYBACK_0_TO_I2S | | ||
646 | PLAYBACK_1_TO_SPDIF | | ||
647 | CAPTURE_0_FROM_I2S_2, | ||
648 | .dac_channels = 8, | ||
649 | .dac_volume_min = 0, | ||
650 | .dac_volume_max = 127, | ||
651 | .function_flags = OXYGEN_FUNCTION_2WIRE, | ||
652 | .dac_i2s_format = OXYGEN_I2S_FORMAT_LJUST, | ||
653 | .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST, | ||
654 | }, | ||
618 | [MODEL_DX] = { | 655 | [MODEL_DX] = { |
619 | .shortname = "Xonar DX", | 656 | .shortname = "Xonar DX", |
620 | .longname = "Asus Virtuoso 100", | 657 | .longname = "Asus Virtuoso 100", |
621 | .chip = "AV200", | 658 | .chip = "AV200", |
622 | .owner = THIS_MODULE, | 659 | .owner = THIS_MODULE, |
623 | .init = xonar_dx_init, | 660 | .init = xonar_dx_init, |
624 | .control_filter = xonar_dx_control_filter, | 661 | .control_filter = xonar_d1_control_filter, |
625 | .mixer_init = xonar_dx_mixer_init, | 662 | .mixer_init = xonar_d1_mixer_init, |
626 | .cleanup = xonar_dx_cleanup, | 663 | .cleanup = xonar_d1_cleanup, |
627 | .suspend = xonar_dx_cleanup, | 664 | .suspend = xonar_d1_cleanup, |
628 | .resume = xonar_dx_resume, | 665 | .resume = xonar_d1_resume, |
629 | .set_dac_params = set_cs43xx_params, | 666 | .set_dac_params = set_cs43xx_params, |
630 | .set_adc_params = set_cs53x1_params, | 667 | .set_adc_params = set_cs53x1_params, |
631 | .update_dac_volume = update_cs43xx_volume, | 668 | .update_dac_volume = update_cs43xx_volume, |
632 | .update_dac_mute = update_cs43xx_mute, | 669 | .update_dac_mute = update_cs43xx_mute, |
633 | .gpio_changed = xonar_gpio_changed, | 670 | .gpio_changed = xonar_gpio_changed, |
634 | .ac97_switch = xonar_dx_ac97_switch, | 671 | .ac97_switch = xonar_d1_ac97_switch, |
635 | .dac_tlv = cs4362a_db_scale, | 672 | .dac_tlv = cs4362a_db_scale, |
636 | .model_data_size = sizeof(struct xonar_data), | 673 | .model_data_size = sizeof(struct xonar_data), |
637 | .pcm_dev_cfg = PLAYBACK_0_TO_I2S | | 674 | .pcm_dev_cfg = PLAYBACK_0_TO_I2S | |
diff --git a/sound/soc/codecs/wm8990.c b/sound/soc/codecs/wm8990.c index 3ecce5168e94..e44153fa38de 100644 --- a/sound/soc/codecs/wm8990.c +++ b/sound/soc/codecs/wm8990.c | |||
@@ -82,7 +82,7 @@ static const u16 wm8990_reg[] = { | |||
82 | 0x0003, /* R35 - ClassD1 */ | 82 | 0x0003, /* R35 - ClassD1 */ |
83 | 0x0000, /* R36 */ | 83 | 0x0000, /* R36 */ |
84 | 0x0100, /* R37 - ClassD3 */ | 84 | 0x0100, /* R37 - ClassD3 */ |
85 | 0x0000, /* R38 */ | 85 | 0x0079, /* R38 - ClassD4 */ |
86 | 0x0000, /* R39 - Input Mixer1 */ | 86 | 0x0000, /* R39 - Input Mixer1 */ |
87 | 0x0000, /* R40 - Input Mixer2 */ | 87 | 0x0000, /* R40 - Input Mixer2 */ |
88 | 0x0000, /* R41 - Input Mixer3 */ | 88 | 0x0000, /* R41 - Input Mixer3 */ |
@@ -311,11 +311,15 @@ SOC_SINGLE("Speaker Mode Switch", WM8990_CLASSD1, | |||
311 | WM8990_CDMODE_BIT, 1, 0), | 311 | WM8990_CDMODE_BIT, 1, 0), |
312 | 312 | ||
313 | SOC_SINGLE("Speaker Output Attenuation Volume", WM8990_SPEAKER_VOLUME, | 313 | SOC_SINGLE("Speaker Output Attenuation Volume", WM8990_SPEAKER_VOLUME, |
314 | WM8990_SPKVOL_SHIFT, WM8990_SPKVOL_MASK, 0), | 314 | WM8990_SPKATTN_SHIFT, WM8990_SPKATTN_MASK, 0), |
315 | SOC_SINGLE("Speaker DC Boost Volume", WM8990_CLASSD3, | 315 | SOC_SINGLE("Speaker DC Boost Volume", WM8990_CLASSD3, |
316 | WM8990_DCGAIN_SHIFT, WM8990_DCGAIN_MASK, 0), | 316 | WM8990_DCGAIN_SHIFT, WM8990_DCGAIN_MASK, 0), |
317 | SOC_SINGLE("Speaker AC Boost Volume", WM8990_CLASSD3, | 317 | SOC_SINGLE("Speaker AC Boost Volume", WM8990_CLASSD3, |
318 | WM8990_ACGAIN_SHIFT, WM8990_ACGAIN_MASK, 0), | 318 | WM8990_ACGAIN_SHIFT, WM8990_ACGAIN_MASK, 0), |
319 | SOC_SINGLE_TLV("Speaker Volume", WM8990_CLASSD4, | ||
320 | WM8990_SPKVOL_SHIFT, WM8990_SPKVOL_MASK, 0, out_pga_tlv), | ||
321 | SOC_SINGLE("Speaker ZC Switch", WM8990_CLASSD4, | ||
322 | WM8990_SPKZC_SHIFT, WM8990_SPKZC_MASK, 0), | ||
319 | 323 | ||
320 | SOC_WM899X_OUTPGA_SINGLE_R_TLV("Left DAC Digital Volume", | 324 | SOC_WM899X_OUTPGA_SINGLE_R_TLV("Left DAC Digital Volume", |
321 | WM8990_LEFT_DAC_DIGITAL_VOLUME, | 325 | WM8990_LEFT_DAC_DIGITAL_VOLUME, |
@@ -920,7 +924,7 @@ static const struct snd_soc_dapm_route audio_map[] = { | |||
920 | {"SPKMIX", "SPKMIX Left Mixer PGA Switch", "LOPGA"}, | 924 | {"SPKMIX", "SPKMIX Left Mixer PGA Switch", "LOPGA"}, |
921 | {"SPKMIX", "SPKMIX Right Mixer PGA Switch", "ROPGA"}, | 925 | {"SPKMIX", "SPKMIX Right Mixer PGA Switch", "ROPGA"}, |
922 | {"SPKMIX", "SPKMIX Right DAC Switch", "Right DAC"}, | 926 | {"SPKMIX", "SPKMIX Right DAC Switch", "Right DAC"}, |
923 | {"SPKMIX", "SPKMIX Left DAC Switch", "Right DAC"}, | 927 | {"SPKMIX", "SPKMIX Left DAC Switch", "Left DAC"}, |
924 | 928 | ||
925 | /* LONMIX */ | 929 | /* LONMIX */ |
926 | {"LONMIX", "LONMIX Left Mixer PGA Switch", "LOPGA"}, | 930 | {"LONMIX", "LONMIX Left Mixer PGA Switch", "LOPGA"}, |
diff --git a/sound/soc/codecs/wm8990.h b/sound/soc/codecs/wm8990.h index 6bea57485283..0a08325d5443 100644 --- a/sound/soc/codecs/wm8990.h +++ b/sound/soc/codecs/wm8990.h | |||
@@ -54,6 +54,7 @@ | |||
54 | #define WM8990_SPEAKER_VOLUME 0x22 | 54 | #define WM8990_SPEAKER_VOLUME 0x22 |
55 | #define WM8990_CLASSD1 0x23 | 55 | #define WM8990_CLASSD1 0x23 |
56 | #define WM8990_CLASSD3 0x25 | 56 | #define WM8990_CLASSD3 0x25 |
57 | #define WM8990_CLASSD4 0x26 | ||
57 | #define WM8990_INPUT_MIXER1 0x27 | 58 | #define WM8990_INPUT_MIXER1 0x27 |
58 | #define WM8990_INPUT_MIXER2 0x28 | 59 | #define WM8990_INPUT_MIXER2 0x28 |
59 | #define WM8990_INPUT_MIXER3 0x29 | 60 | #define WM8990_INPUT_MIXER3 0x29 |
@@ -528,8 +529,8 @@ | |||
528 | /* | 529 | /* |
529 | * R34 (0x22) - Speaker Volume | 530 | * R34 (0x22) - Speaker Volume |
530 | */ | 531 | */ |
531 | #define WM8990_SPKVOL_MASK 0x0003 /* SPKVOL - [1:0] */ | 532 | #define WM8990_SPKATTN_MASK 0x0003 /* SPKATTN - [1:0] */ |
532 | #define WM8990_SPKVOL_SHIFT 0 | 533 | #define WM8990_SPKATTN_SHIFT 0 |
533 | 534 | ||
534 | /* | 535 | /* |
535 | * R35 (0x23) - ClassD1 | 536 | * R35 (0x23) - ClassD1 |
@@ -544,6 +545,15 @@ | |||
544 | #define WM8990_DCGAIN_SHIFT 3 | 545 | #define WM8990_DCGAIN_SHIFT 3 |
545 | #define WM8990_ACGAIN_MASK 0x0007 /* ACGAIN - [2:0] */ | 546 | #define WM8990_ACGAIN_MASK 0x0007 /* ACGAIN - [2:0] */ |
546 | #define WM8990_ACGAIN_SHIFT 0 | 547 | #define WM8990_ACGAIN_SHIFT 0 |
548 | |||
549 | /* | ||
550 | * R38 (0x26) - ClassD4 | ||
551 | */ | ||
552 | #define WM8990_SPKZC_MASK 0x0001 /* SPKZC */ | ||
553 | #define WM8990_SPKZC_SHIFT 7 /* SPKZC */ | ||
554 | #define WM8990_SPKVOL_MASK 0x007F /* SPKVOL - [6:0] */ | ||
555 | #define WM8990_SPKVOL_SHIFT 0 /* SPKVOL - [6:0] */ | ||
556 | |||
547 | /* | 557 | /* |
548 | * R39 (0x27) - Input Mixer1 | 558 | * R39 (0x27) - Input Mixer1 |
549 | */ | 559 | */ |