Commit b217d532e65b30ea1aaf8165809bdf457b8a6e65

Authored by Kailang Yang
Committed by Greg Kroah-Hartman
1 parent 1979d0bf95

ALSA: hda/realtek - Add support for ALC295/ALC3254

commit 7d727869c7b86da0874436ac5675dcdadaf3a0a1 upstream.

Add support for ALC295/ALC3254.
They are simply compatible with ALC225 chip.

Signed-off-by: Kailang Yang <kailang@realtek.com>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

Showing 1 changed file with 10 additions and 0 deletions Side-by-side Diff

sound/pci/hda/patch_realtek.c
... ... @@ -335,6 +335,7 @@
335 335 case 0x10ec0283:
336 336 case 0x10ec0286:
337 337 case 0x10ec0288:
  338 + case 0x10ec0295:
338 339 case 0x10ec0298:
339 340 alc_update_coef_idx(codec, 0x10, 1<<9, 0);
340 341 break;
... ... @@ -907,6 +908,7 @@
907 908 { 0x10ec0298, 0x1028, 0, "ALC3266" },
908 909 { 0x10ec0256, 0x1028, 0, "ALC3246" },
909 910 { 0x10ec0225, 0x1028, 0, "ALC3253" },
  911 + { 0x10ec0295, 0x1028, 0, "ALC3254" },
910 912 { 0x10ec0670, 0x1025, 0, "ALC669X" },
911 913 { 0x10ec0676, 0x1025, 0, "ALC679X" },
912 914 { 0x10ec0282, 0x1043, 0, "ALC3229" },
... ... @@ -3697,6 +3699,7 @@
3697 3699 alc_process_coef_fw(codec, coef0668);
3698 3700 break;
3699 3701 case 0x10ec0225:
  3702 + case 0x10ec0295:
3700 3703 alc_process_coef_fw(codec, coef0225);
3701 3704 break;
3702 3705 }
... ... @@ -3797,6 +3800,7 @@
3797 3800 snd_hda_set_pin_ctl_cache(codec, mic_pin, PIN_VREF50);
3798 3801 break;
3799 3802 case 0x10ec0225:
  3803 + case 0x10ec0295:
3800 3804 alc_update_coef_idx(codec, 0x45, 0x3f<<10, 0x31<<10);
3801 3805 snd_hda_set_pin_ctl_cache(codec, hp_pin, 0);
3802 3806 alc_process_coef_fw(codec, coef0225);
... ... @@ -3854,6 +3858,7 @@
3854 3858  
3855 3859 switch (codec->core.vendor_id) {
3856 3860 case 0x10ec0225:
  3861 + case 0x10ec0295:
3857 3862 alc_process_coef_fw(codec, coef0225);
3858 3863 break;
3859 3864 case 0x10ec0255:
... ... @@ -3957,6 +3962,7 @@
3957 3962 alc_process_coef_fw(codec, coef0688);
3958 3963 break;
3959 3964 case 0x10ec0225:
  3965 + case 0x10ec0295:
3960 3966 alc_process_coef_fw(codec, coef0225);
3961 3967 break;
3962 3968 }
... ... @@ -4038,6 +4044,7 @@
4038 4044 alc_process_coef_fw(codec, coef0688);
4039 4045 break;
4040 4046 case 0x10ec0225:
  4047 + case 0x10ec0295:
4041 4048 alc_process_coef_fw(codec, coef0225);
4042 4049 break;
4043 4050 }
... ... @@ -4121,6 +4128,7 @@
4121 4128 is_ctia = (val & 0x1c02) == 0x1c02;
4122 4129 break;
4123 4130 case 0x10ec0225:
  4131 + case 0x10ec0295:
4124 4132 alc_process_coef_fw(codec, coef0225);
4125 4133 msleep(800);
4126 4134 val = alc_read_coef_idx(codec, 0x46);
... ... @@ -6034,6 +6042,7 @@
6034 6042 alc_update_coef_idx(codec, 0x36, 1 << 13, 1 << 5); /* Switch pcbeep path to Line in path*/
6035 6043 break;
6036 6044 case 0x10ec0225:
  6045 + case 0x10ec0295:
6037 6046 spec->codec_variant = ALC269_TYPE_ALC225;
6038 6047 break;
6039 6048 case 0x10ec0234:
... ... @@ -6980,6 +6989,7 @@
6980 6989 HDA_CODEC_ENTRY(0x10ec0292, "ALC292", patch_alc269),
6981 6990 HDA_CODEC_ENTRY(0x10ec0293, "ALC293", patch_alc269),
6982 6991 HDA_CODEC_ENTRY(0x10ec0294, "ALC294", patch_alc269),
  6992 + HDA_CODEC_ENTRY(0x10ec0295, "ALC295", patch_alc269),
6983 6993 HDA_CODEC_ENTRY(0x10ec0298, "ALC298", patch_alc269),
6984 6994 HDA_CODEC_REV_ENTRY(0x10ec0861, 0x100340, "ALC660", patch_alc861),
6985 6995 HDA_CODEC_ENTRY(0x10ec0660, "ALC660-VD", patch_alc861vd),