diff options
-rw-r--r-- | sound/pci/hda/patch_realtek.c | 136 |
1 files changed, 61 insertions, 75 deletions
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index 6dd1b74e9f68..ae9732ce8670 100644 --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c | |||
@@ -4405,6 +4405,25 @@ static int alc_parse_auto_config(struct hda_codec *codec, | |||
4405 | return 1; | 4405 | return 1; |
4406 | } | 4406 | } |
4407 | 4407 | ||
4408 | /* common preparation job for alc_spec */ | ||
4409 | static int alc_alloc_spec(struct hda_codec *codec, hda_nid_t mixer_nid) | ||
4410 | { | ||
4411 | struct alc_spec *spec = kzalloc(sizeof(*spec), GFP_KERNEL); | ||
4412 | int err; | ||
4413 | |||
4414 | if (!spec) | ||
4415 | return -ENOMEM; | ||
4416 | codec->spec = spec; | ||
4417 | spec->mixer_nid = mixer_nid; | ||
4418 | |||
4419 | err = alc_codec_rename_from_preset(codec); | ||
4420 | if (err < 0) { | ||
4421 | kfree(spec); | ||
4422 | return err; | ||
4423 | } | ||
4424 | return 0; | ||
4425 | } | ||
4426 | |||
4408 | static int alc880_parse_auto_config(struct hda_codec *codec) | 4427 | static int alc880_parse_auto_config(struct hda_codec *codec) |
4409 | { | 4428 | { |
4410 | static const hda_nid_t alc880_ignore[] = { 0x1d, 0 }; | 4429 | static const hda_nid_t alc880_ignore[] = { 0x1d, 0 }; |
@@ -4786,13 +4805,11 @@ static int patch_alc880(struct hda_codec *codec) | |||
4786 | struct alc_spec *spec; | 4805 | struct alc_spec *spec; |
4787 | int err; | 4806 | int err; |
4788 | 4807 | ||
4789 | spec = kzalloc(sizeof(*spec), GFP_KERNEL); | 4808 | err = alc_alloc_spec(codec, 0x0b); |
4790 | if (spec == NULL) | 4809 | if (err < 0) |
4791 | return -ENOMEM; | 4810 | return err; |
4792 | |||
4793 | codec->spec = spec; | ||
4794 | 4811 | ||
4795 | spec->mixer_nid = 0x0b; | 4812 | spec = codec->spec; |
4796 | spec->need_dac_fix = 1; | 4813 | spec->need_dac_fix = 1; |
4797 | 4814 | ||
4798 | alc_pick_fixup(codec, alc880_fixup_models, alc880_fixup_tbl, | 4815 | alc_pick_fixup(codec, alc880_fixup_models, alc880_fixup_tbl, |
@@ -4979,13 +4996,11 @@ static int patch_alc260(struct hda_codec *codec) | |||
4979 | struct alc_spec *spec; | 4996 | struct alc_spec *spec; |
4980 | int err; | 4997 | int err; |
4981 | 4998 | ||
4982 | spec = kzalloc(sizeof(*spec), GFP_KERNEL); | 4999 | err = alc_alloc_spec(codec, 0x07); |
4983 | if (spec == NULL) | 5000 | if (err < 0) |
4984 | return -ENOMEM; | 5001 | return err; |
4985 | |||
4986 | codec->spec = spec; | ||
4987 | 5002 | ||
4988 | spec->mixer_nid = 0x07; | 5003 | spec = codec->spec; |
4989 | 5004 | ||
4990 | alc_pick_fixup(codec, NULL, alc260_fixup_tbl, alc260_fixups); | 5005 | alc_pick_fixup(codec, NULL, alc260_fixup_tbl, alc260_fixups); |
4991 | alc_apply_fixup(codec, ALC_FIXUP_ACT_PRE_PROBE); | 5006 | alc_apply_fixup(codec, ALC_FIXUP_ACT_PRE_PROBE); |
@@ -5452,13 +5467,11 @@ static int patch_alc882(struct hda_codec *codec) | |||
5452 | struct alc_spec *spec; | 5467 | struct alc_spec *spec; |
5453 | int err; | 5468 | int err; |
5454 | 5469 | ||
5455 | spec = kzalloc(sizeof(*spec), GFP_KERNEL); | 5470 | err = alc_alloc_spec(codec, 0x0b); |
5456 | if (spec == NULL) | 5471 | if (err < 0) |
5457 | return -ENOMEM; | 5472 | return err; |
5458 | |||
5459 | codec->spec = spec; | ||
5460 | 5473 | ||
5461 | spec->mixer_nid = 0x0b; | 5474 | spec = codec->spec; |
5462 | 5475 | ||
5463 | switch (codec->vendor_id) { | 5476 | switch (codec->vendor_id) { |
5464 | case 0x10ec0882: | 5477 | case 0x10ec0882: |
@@ -5470,10 +5483,6 @@ static int patch_alc882(struct hda_codec *codec) | |||
5470 | break; | 5483 | break; |
5471 | } | 5484 | } |
5472 | 5485 | ||
5473 | err = alc_codec_rename_from_preset(codec); | ||
5474 | if (err < 0) | ||
5475 | goto error; | ||
5476 | |||
5477 | alc_pick_fixup(codec, alc882_fixup_models, alc882_fixup_tbl, | 5486 | alc_pick_fixup(codec, alc882_fixup_models, alc882_fixup_tbl, |
5478 | alc882_fixups); | 5487 | alc882_fixups); |
5479 | alc_apply_fixup(codec, ALC_FIXUP_ACT_PRE_PROBE); | 5488 | alc_apply_fixup(codec, ALC_FIXUP_ACT_PRE_PROBE); |
@@ -5597,13 +5606,11 @@ static int patch_alc262(struct hda_codec *codec) | |||
5597 | struct alc_spec *spec; | 5606 | struct alc_spec *spec; |
5598 | int err; | 5607 | int err; |
5599 | 5608 | ||
5600 | spec = kzalloc(sizeof(*spec), GFP_KERNEL); | 5609 | err = alc_alloc_spec(codec, 0x0b); |
5601 | if (spec == NULL) | 5610 | if (err < 0) |
5602 | return -ENOMEM; | 5611 | return err; |
5603 | |||
5604 | codec->spec = spec; | ||
5605 | 5612 | ||
5606 | spec->mixer_nid = 0x0b; | 5613 | spec = codec->spec; |
5607 | 5614 | ||
5608 | #if 0 | 5615 | #if 0 |
5609 | /* pshou 07/11/05 set a zero PCM sample to DAC when FIFO is | 5616 | /* pshou 07/11/05 set a zero PCM sample to DAC when FIFO is |
@@ -5699,13 +5706,12 @@ static int patch_alc268(struct hda_codec *codec) | |||
5699 | struct alc_spec *spec; | 5706 | struct alc_spec *spec; |
5700 | int i, has_beep, err; | 5707 | int i, has_beep, err; |
5701 | 5708 | ||
5702 | spec = kzalloc(sizeof(*spec), GFP_KERNEL); | ||
5703 | if (spec == NULL) | ||
5704 | return -ENOMEM; | ||
5705 | |||
5706 | codec->spec = spec; | ||
5707 | |||
5708 | /* ALC268 has no aa-loopback mixer */ | 5709 | /* ALC268 has no aa-loopback mixer */ |
5710 | err = alc_alloc_spec(codec, 0); | ||
5711 | if (err < 0) | ||
5712 | return err; | ||
5713 | |||
5714 | spec = codec->spec; | ||
5709 | 5715 | ||
5710 | /* automatic parse from the BIOS config */ | 5716 | /* automatic parse from the BIOS config */ |
5711 | err = alc268_parse_auto_config(codec); | 5717 | err = alc268_parse_auto_config(codec); |
@@ -6216,19 +6222,13 @@ static void alc269_fill_coef(struct hda_codec *codec) | |||
6216 | static int patch_alc269(struct hda_codec *codec) | 6222 | static int patch_alc269(struct hda_codec *codec) |
6217 | { | 6223 | { |
6218 | struct alc_spec *spec; | 6224 | struct alc_spec *spec; |
6219 | int err = 0; | 6225 | int err; |
6220 | |||
6221 | spec = kzalloc(sizeof(*spec), GFP_KERNEL); | ||
6222 | if (spec == NULL) | ||
6223 | return -ENOMEM; | ||
6224 | |||
6225 | codec->spec = spec; | ||
6226 | |||
6227 | spec->mixer_nid = 0x0b; | ||
6228 | 6226 | ||
6229 | err = alc_codec_rename_from_preset(codec); | 6227 | err = alc_alloc_spec(codec, 0x0b); |
6230 | if (err < 0) | 6228 | if (err < 0) |
6231 | goto error; | 6229 | return err; |
6230 | |||
6231 | spec = codec->spec; | ||
6232 | 6232 | ||
6233 | if (codec->vendor_id == 0x10ec0269) { | 6233 | if (codec->vendor_id == 0x10ec0269) { |
6234 | spec->codec_variant = ALC269_TYPE_ALC269VA; | 6234 | spec->codec_variant = ALC269_TYPE_ALC269VA; |
@@ -6374,13 +6374,11 @@ static int patch_alc861(struct hda_codec *codec) | |||
6374 | struct alc_spec *spec; | 6374 | struct alc_spec *spec; |
6375 | int err; | 6375 | int err; |
6376 | 6376 | ||
6377 | spec = kzalloc(sizeof(*spec), GFP_KERNEL); | 6377 | err = alc_alloc_spec(codec, 0x15); |
6378 | if (spec == NULL) | 6378 | if (err < 0) |
6379 | return -ENOMEM; | 6379 | return err; |
6380 | |||
6381 | codec->spec = spec; | ||
6382 | 6380 | ||
6383 | spec->mixer_nid = 0x15; | 6381 | spec = codec->spec; |
6384 | 6382 | ||
6385 | alc_pick_fixup(codec, NULL, alc861_fixup_tbl, alc861_fixups); | 6383 | alc_pick_fixup(codec, NULL, alc861_fixup_tbl, alc861_fixups); |
6386 | alc_apply_fixup(codec, ALC_FIXUP_ACT_PRE_PROBE); | 6384 | alc_apply_fixup(codec, ALC_FIXUP_ACT_PRE_PROBE); |
@@ -6477,13 +6475,11 @@ static int patch_alc861vd(struct hda_codec *codec) | |||
6477 | struct alc_spec *spec; | 6475 | struct alc_spec *spec; |
6478 | int err; | 6476 | int err; |
6479 | 6477 | ||
6480 | spec = kzalloc(sizeof(*spec), GFP_KERNEL); | 6478 | err = alc_alloc_spec(codec, 0x0b); |
6481 | if (spec == NULL) | 6479 | if (err < 0) |
6482 | return -ENOMEM; | 6480 | return err; |
6483 | |||
6484 | codec->spec = spec; | ||
6485 | 6481 | ||
6486 | spec->mixer_nid = 0x0b; | 6482 | spec = codec->spec; |
6487 | 6483 | ||
6488 | alc_pick_fixup(codec, NULL, alc861vd_fixup_tbl, alc861vd_fixups); | 6484 | alc_pick_fixup(codec, NULL, alc861vd_fixup_tbl, alc861vd_fixups); |
6489 | alc_apply_fixup(codec, ALC_FIXUP_ACT_PRE_PROBE); | 6485 | alc_apply_fixup(codec, ALC_FIXUP_ACT_PRE_PROBE); |
@@ -6822,25 +6818,19 @@ static const struct alc_model_fixup alc662_fixup_models[] = { | |||
6822 | static int patch_alc662(struct hda_codec *codec) | 6818 | static int patch_alc662(struct hda_codec *codec) |
6823 | { | 6819 | { |
6824 | struct alc_spec *spec; | 6820 | struct alc_spec *spec; |
6825 | int err = 0; | 6821 | int err; |
6826 | |||
6827 | spec = kzalloc(sizeof(*spec), GFP_KERNEL); | ||
6828 | if (!spec) | ||
6829 | return -ENOMEM; | ||
6830 | 6822 | ||
6831 | codec->spec = spec; | 6823 | err = alc_alloc_spec(codec, 0x0b); |
6824 | if (err < 0) | ||
6825 | return err; | ||
6832 | 6826 | ||
6833 | spec->mixer_nid = 0x0b; | 6827 | spec = codec->spec; |
6834 | 6828 | ||
6835 | /* handle multiple HPs as is */ | 6829 | /* handle multiple HPs as is */ |
6836 | spec->parse_flags = HDA_PINCFG_NO_HP_FIXUP; | 6830 | spec->parse_flags = HDA_PINCFG_NO_HP_FIXUP; |
6837 | 6831 | ||
6838 | alc_fix_pll_init(codec, 0x20, 0x04, 15); | 6832 | alc_fix_pll_init(codec, 0x20, 0x04, 15); |
6839 | 6833 | ||
6840 | err = alc_codec_rename_from_preset(codec); | ||
6841 | if (err < 0) | ||
6842 | goto error; | ||
6843 | |||
6844 | if ((alc_get_coef0(codec) & (1 << 14)) && | 6834 | if ((alc_get_coef0(codec) & (1 << 14)) && |
6845 | codec->bus->pci->subsystem_vendor == 0x1025 && | 6835 | codec->bus->pci->subsystem_vendor == 0x1025 && |
6846 | spec->cdefine.platform_type == 1) { | 6836 | spec->cdefine.platform_type == 1) { |
@@ -6903,16 +6893,12 @@ static int alc680_parse_auto_config(struct hda_codec *codec) | |||
6903 | */ | 6893 | */ |
6904 | static int patch_alc680(struct hda_codec *codec) | 6894 | static int patch_alc680(struct hda_codec *codec) |
6905 | { | 6895 | { |
6906 | struct alc_spec *spec; | ||
6907 | int err; | 6896 | int err; |
6908 | 6897 | ||
6909 | spec = kzalloc(sizeof(*spec), GFP_KERNEL); | ||
6910 | if (spec == NULL) | ||
6911 | return -ENOMEM; | ||
6912 | |||
6913 | codec->spec = spec; | ||
6914 | |||
6915 | /* ALC680 has no aa-loopback mixer */ | 6898 | /* ALC680 has no aa-loopback mixer */ |
6899 | err = alc_alloc_spec(codec, 0); | ||
6900 | if (err < 0) | ||
6901 | return err; | ||
6916 | 6902 | ||
6917 | /* automatic parse from the BIOS config */ | 6903 | /* automatic parse from the BIOS config */ |
6918 | err = alc680_parse_auto_config(codec); | 6904 | err = alc680_parse_auto_config(codec); |