aboutsummaryrefslogtreecommitdiffstats
path: root/sound/pci
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2012-02-21 05:27:09 -0500
committerTakashi Iwai <tiwai@suse.de>2012-02-21 05:28:51 -0500
commit164f73ee93131f67a61eaca6a6f6180580c39445 (patch)
treeb61b8a2f3c527646df3dcb9b9ee3b0219e4aca5d /sound/pci
parent1a97b7f22774b454531f013638b181803fba470f (diff)
ALSA: hda/realtek - Parse aa-loopback items dynamically
Similarly in patch_via.c, parse the active analog-loopback connections and create a list dynamically rather than static arrays. Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/pci')
-rw-r--r--sound/pci/hda/patch_realtek.c104
1 files changed, 22 insertions, 82 deletions
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c
index c5216b58d218..eba50dff6130 100644
--- a/sound/pci/hda/patch_realtek.c
+++ b/sound/pci/hda/patch_realtek.c
@@ -200,6 +200,8 @@ struct alc_spec {
200 hda_nid_t vmaster_nid; 200 hda_nid_t vmaster_nid;
201#ifdef CONFIG_SND_HDA_POWER_SAVE 201#ifdef CONFIG_SND_HDA_POWER_SAVE
202 struct hda_loopback_check loopback; 202 struct hda_loopback_check loopback;
203 int num_loopbacks;
204 struct hda_amp_list loopback_list[8];
203#endif 205#endif
204 206
205 /* for PLL fix */ 207 /* for PLL fix */
@@ -2690,6 +2692,25 @@ static const char *alc_get_line_out_pfx(struct alc_spec *spec, int ch,
2690 return channel_name[ch]; 2692 return channel_name[ch];
2691} 2693}
2692 2694
2695#ifdef CONFIG_SND_HDA_POWER_SAVE
2696/* add the powersave loopback-list entry */
2697static void add_loopback_list(struct alc_spec *spec, hda_nid_t mix, int idx)
2698{
2699 struct hda_amp_list *list;
2700
2701 if (spec->num_loopbacks >= ARRAY_SIZE(spec->loopback_list) - 1)
2702 return;
2703 list = spec->loopback_list + spec->num_loopbacks;
2704 list->nid = mix;
2705 list->dir = HDA_INPUT;
2706 list->idx = idx;
2707 spec->num_loopbacks++;
2708 spec->loopback.amplist = spec->loopback_list;
2709}
2710#else
2711#define add_loopback_list(spec, mix, idx) /* NOP */
2712#endif
2713
2693/* create input playback/capture controls for the given pin */ 2714/* create input playback/capture controls for the given pin */
2694static int new_analog_input(struct alc_spec *spec, hda_nid_t pin, 2715static int new_analog_input(struct alc_spec *spec, hda_nid_t pin,
2695 const char *ctlname, int ctlidx, 2716 const char *ctlname, int ctlidx,
@@ -2705,6 +2726,7 @@ static int new_analog_input(struct alc_spec *spec, hda_nid_t pin,
2705 HDA_COMPOSE_AMP_VAL(mix_nid, 3, idx, HDA_INPUT)); 2726 HDA_COMPOSE_AMP_VAL(mix_nid, 3, idx, HDA_INPUT));
2706 if (err < 0) 2727 if (err < 0)
2707 return err; 2728 return err;
2729 add_loopback_list(spec, mix_nid, idx);
2708 return 0; 2730 return 0;
2709} 2731}
2710 2732
@@ -4430,17 +4452,6 @@ static int alc880_parse_auto_config(struct hda_codec *codec)
4430 return alc_parse_auto_config(codec, alc880_ignore, alc880_ssids); 4452 return alc_parse_auto_config(codec, alc880_ignore, alc880_ssids);
4431} 4453}
4432 4454
4433#ifdef CONFIG_SND_HDA_POWER_SAVE
4434static const struct hda_amp_list alc880_loopbacks[] = {
4435 { 0x0b, HDA_INPUT, 0 },
4436 { 0x0b, HDA_INPUT, 1 },
4437 { 0x0b, HDA_INPUT, 2 },
4438 { 0x0b, HDA_INPUT, 3 },
4439 { 0x0b, HDA_INPUT, 4 },
4440 { } /* end */
4441};
4442#endif
4443
4444/* 4455/*
4445 * ALC880 fix-ups 4456 * ALC880 fix-ups
4446 */ 4457 */
@@ -4851,10 +4862,6 @@ static int patch_alc880(struct hda_codec *codec)
4851 4862
4852 codec->patch_ops = alc_patch_ops; 4863 codec->patch_ops = alc_patch_ops;
4853 spec->init_hook = alc_auto_init_std; 4864 spec->init_hook = alc_auto_init_std;
4854#ifdef CONFIG_SND_HDA_POWER_SAVE
4855 if (!spec->loopback.amplist)
4856 spec->loopback.amplist = alc880_loopbacks;
4857#endif
4858 4865
4859 alc_apply_fixup(codec, ALC_FIXUP_ACT_PROBE); 4866 alc_apply_fixup(codec, ALC_FIXUP_ACT_PROBE);
4860 4867
@@ -4876,17 +4883,6 @@ static int alc260_parse_auto_config(struct hda_codec *codec)
4876 return alc_parse_auto_config(codec, alc260_ignore, alc260_ssids); 4883 return alc_parse_auto_config(codec, alc260_ignore, alc260_ssids);
4877} 4884}
4878 4885
4879#ifdef CONFIG_SND_HDA_POWER_SAVE
4880static const struct hda_amp_list alc260_loopbacks[] = {
4881 { 0x07, HDA_INPUT, 0 },
4882 { 0x07, HDA_INPUT, 1 },
4883 { 0x07, HDA_INPUT, 2 },
4884 { 0x07, HDA_INPUT, 3 },
4885 { 0x07, HDA_INPUT, 4 },
4886 { } /* end */
4887};
4888#endif
4889
4890/* 4886/*
4891 * Pin config fixes 4887 * Pin config fixes
4892 */ 4888 */
@@ -5032,10 +5028,6 @@ static int patch_alc260(struct hda_codec *codec)
5032 codec->patch_ops = alc_patch_ops; 5028 codec->patch_ops = alc_patch_ops;
5033 spec->init_hook = alc_auto_init_std; 5029 spec->init_hook = alc_auto_init_std;
5034 spec->shutup = alc_eapd_shutup; 5030 spec->shutup = alc_eapd_shutup;
5035#ifdef CONFIG_SND_HDA_POWER_SAVE
5036 if (!spec->loopback.amplist)
5037 spec->loopback.amplist = alc260_loopbacks;
5038#endif
5039 5031
5040 alc_apply_fixup(codec, ALC_FIXUP_ACT_PROBE); 5032 alc_apply_fixup(codec, ALC_FIXUP_ACT_PROBE);
5041 5033
@@ -5058,9 +5050,6 @@ static int patch_alc260(struct hda_codec *codec)
5058 * In addition, an independent DAC for the multi-playback (not used in this 5050 * In addition, an independent DAC for the multi-playback (not used in this
5059 * driver yet). 5051 * driver yet).
5060 */ 5052 */
5061#ifdef CONFIG_SND_HDA_POWER_SAVE
5062#define alc882_loopbacks alc880_loopbacks
5063#endif
5064 5053
5065/* 5054/*
5066 * Pin config fixes 5055 * Pin config fixes
@@ -5507,11 +5496,6 @@ static int patch_alc882(struct hda_codec *codec)
5507 codec->patch_ops = alc_patch_ops; 5496 codec->patch_ops = alc_patch_ops;
5508 spec->init_hook = alc_auto_init_std; 5497 spec->init_hook = alc_auto_init_std;
5509 5498
5510#ifdef CONFIG_SND_HDA_POWER_SAVE
5511 if (!spec->loopback.amplist)
5512 spec->loopback.amplist = alc882_loopbacks;
5513#endif
5514
5515 alc_apply_fixup(codec, ALC_FIXUP_ACT_PROBE); 5499 alc_apply_fixup(codec, ALC_FIXUP_ACT_PROBE);
5516 5500
5517 return 0; 5501 return 0;
@@ -5608,10 +5592,6 @@ static const struct snd_pci_quirk alc262_fixup_tbl[] = {
5608}; 5592};
5609 5593
5610 5594
5611#ifdef CONFIG_SND_HDA_POWER_SAVE
5612#define alc262_loopbacks alc880_loopbacks
5613#endif
5614
5615/* 5595/*
5616 */ 5596 */
5617static int patch_alc262(struct hda_codec *codec) 5597static int patch_alc262(struct hda_codec *codec)
@@ -5671,11 +5651,6 @@ static int patch_alc262(struct hda_codec *codec)
5671 spec->init_hook = alc_auto_init_std; 5651 spec->init_hook = alc_auto_init_std;
5672 spec->shutup = alc_eapd_shutup; 5652 spec->shutup = alc_eapd_shutup;
5673 5653
5674#ifdef CONFIG_SND_HDA_POWER_SAVE
5675 if (!spec->loopback.amplist)
5676 spec->loopback.amplist = alc262_loopbacks;
5677#endif
5678
5679 alc_apply_fixup(codec, ALC_FIXUP_ACT_PROBE); 5654 alc_apply_fixup(codec, ALC_FIXUP_ACT_PROBE);
5680 5655
5681 return 0; 5656 return 0;
@@ -5793,10 +5768,6 @@ static int patch_alc268(struct hda_codec *codec)
5793/* 5768/*
5794 * ALC269 5769 * ALC269
5795 */ 5770 */
5796#ifdef CONFIG_SND_HDA_POWER_SAVE
5797#define alc269_loopbacks alc880_loopbacks
5798#endif
5799
5800static const struct hda_pcm_stream alc269_44k_pcm_analog_playback = { 5771static const struct hda_pcm_stream alc269_44k_pcm_analog_playback = {
5801 .substreams = 1, 5772 .substreams = 1,
5802 .channels_min = 2, 5773 .channels_min = 2,
@@ -6336,8 +6307,6 @@ static int patch_alc269(struct hda_codec *codec)
6336 spec->shutup = alc269_shutup; 6307 spec->shutup = alc269_shutup;
6337 6308
6338#ifdef CONFIG_SND_HDA_POWER_SAVE 6309#ifdef CONFIG_SND_HDA_POWER_SAVE
6339 if (!spec->loopback.amplist)
6340 spec->loopback.amplist = alc269_loopbacks;
6341 if (alc269_mic2_for_mute_led(codec)) 6310 if (alc269_mic2_for_mute_led(codec))
6342 codec->patch_ops.check_power_status = alc269_mic2_mute_check_ps; 6311 codec->patch_ops.check_power_status = alc269_mic2_mute_check_ps;
6343#endif 6312#endif
@@ -6362,17 +6331,6 @@ static int alc861_parse_auto_config(struct hda_codec *codec)
6362 return alc_parse_auto_config(codec, alc861_ignore, alc861_ssids); 6331 return alc_parse_auto_config(codec, alc861_ignore, alc861_ssids);
6363} 6332}
6364 6333
6365#ifdef CONFIG_SND_HDA_POWER_SAVE
6366static const struct hda_amp_list alc861_loopbacks[] = {
6367 { 0x15, HDA_INPUT, 0 },
6368 { 0x15, HDA_INPUT, 1 },
6369 { 0x15, HDA_INPUT, 2 },
6370 { 0x15, HDA_INPUT, 3 },
6371 { } /* end */
6372};
6373#endif
6374
6375
6376/* Pin config fixes */ 6334/* Pin config fixes */
6377enum { 6335enum {
6378 ALC861_FIXUP_FSC_AMILO_PI1505, 6336 ALC861_FIXUP_FSC_AMILO_PI1505,
@@ -6486,8 +6444,6 @@ static int patch_alc861(struct hda_codec *codec)
6486 spec->init_hook = alc_auto_init_std; 6444 spec->init_hook = alc_auto_init_std;
6487#ifdef CONFIG_SND_HDA_POWER_SAVE 6445#ifdef CONFIG_SND_HDA_POWER_SAVE
6488 spec->power_hook = alc_power_eapd; 6446 spec->power_hook = alc_power_eapd;
6489 if (!spec->loopback.amplist)
6490 spec->loopback.amplist = alc861_loopbacks;
6491#endif 6447#endif
6492 6448
6493 alc_apply_fixup(codec, ALC_FIXUP_ACT_PROBE); 6449 alc_apply_fixup(codec, ALC_FIXUP_ACT_PROBE);
@@ -6506,10 +6462,6 @@ static int patch_alc861(struct hda_codec *codec)
6506 * 6462 *
6507 * In addition, an independent DAC 6463 * In addition, an independent DAC
6508 */ 6464 */
6509#ifdef CONFIG_SND_HDA_POWER_SAVE
6510#define alc861vd_loopbacks alc880_loopbacks
6511#endif
6512
6513static int alc861vd_parse_auto_config(struct hda_codec *codec) 6465static int alc861vd_parse_auto_config(struct hda_codec *codec)
6514{ 6466{
6515 static const hda_nid_t alc861vd_ignore[] = { 0x1d, 0 }; 6467 static const hda_nid_t alc861vd_ignore[] = { 0x1d, 0 };
@@ -6610,10 +6562,6 @@ static int patch_alc861vd(struct hda_codec *codec)
6610 6562
6611 spec->init_hook = alc_auto_init_std; 6563 spec->init_hook = alc_auto_init_std;
6612 spec->shutup = alc_eapd_shutup; 6564 spec->shutup = alc_eapd_shutup;
6613#ifdef CONFIG_SND_HDA_POWER_SAVE
6614 if (!spec->loopback.amplist)
6615 spec->loopback.amplist = alc861vd_loopbacks;
6616#endif
6617 6565
6618 alc_apply_fixup(codec, ALC_FIXUP_ACT_PROBE); 6566 alc_apply_fixup(codec, ALC_FIXUP_ACT_PROBE);
6619 6567
@@ -6635,9 +6583,6 @@ static int patch_alc861vd(struct hda_codec *codec)
6635 * In addition, an independent DAC for the multi-playback (not used in this 6583 * In addition, an independent DAC for the multi-playback (not used in this
6636 * driver yet). 6584 * driver yet).
6637 */ 6585 */
6638#ifdef CONFIG_SND_HDA_POWER_SAVE
6639#define alc662_loopbacks alc880_loopbacks
6640#endif
6641 6586
6642/* 6587/*
6643 * BIOS auto configuration 6588 * BIOS auto configuration
@@ -6999,11 +6944,6 @@ static int patch_alc662(struct hda_codec *codec)
6999 spec->init_hook = alc_auto_init_std; 6944 spec->init_hook = alc_auto_init_std;
7000 spec->shutup = alc_eapd_shutup; 6945 spec->shutup = alc_eapd_shutup;
7001 6946
7002#ifdef CONFIG_SND_HDA_POWER_SAVE
7003 if (!spec->loopback.amplist)
7004 spec->loopback.amplist = alc662_loopbacks;
7005#endif
7006
7007 alc_apply_fixup(codec, ALC_FIXUP_ACT_PROBE); 6947 alc_apply_fixup(codec, ALC_FIXUP_ACT_PROBE);
7008 6948
7009 return 0; 6949 return 0;