Commit 1a5bc8d9 authored by Kailang Yang's avatar Kailang Yang Committed by Takashi Iwai

ALSA: hda/realtek - Support headset mode for ALC298

Support headset mode for ALC298 platform.
Signed-off-by: default avatarKailang Yang <kailang@realtek.com>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent fd8a1043
...@@ -3583,6 +3583,7 @@ static void alc_headset_mode_unplugged(struct hda_codec *codec) ...@@ -3583,6 +3583,7 @@ static void alc_headset_mode_unplugged(struct hda_codec *codec)
break; break;
case 0x10ec0286: case 0x10ec0286:
case 0x10ec0288: case 0x10ec0288:
case 0x10ec0298:
alc_process_coef_fw(codec, coef0288); alc_process_coef_fw(codec, coef0288);
break; break;
case 0x10ec0292: case 0x10ec0292:
...@@ -3657,6 +3658,7 @@ static void alc_headset_mode_mic_in(struct hda_codec *codec, hda_nid_t hp_pin, ...@@ -3657,6 +3658,7 @@ static void alc_headset_mode_mic_in(struct hda_codec *codec, hda_nid_t hp_pin,
break; break;
case 0x10ec0286: case 0x10ec0286:
case 0x10ec0288: case 0x10ec0288:
case 0x10ec0298:
alc_update_coef_idx(codec, 0x4f, 0x000c, 0); alc_update_coef_idx(codec, 0x4f, 0x000c, 0);
snd_hda_set_pin_ctl_cache(codec, hp_pin, 0); snd_hda_set_pin_ctl_cache(codec, hp_pin, 0);
alc_process_coef_fw(codec, coef0288); alc_process_coef_fw(codec, coef0288);
...@@ -3736,6 +3738,7 @@ static void alc_headset_mode_default(struct hda_codec *codec) ...@@ -3736,6 +3738,7 @@ static void alc_headset_mode_default(struct hda_codec *codec)
break; break;
case 0x10ec0286: case 0x10ec0286:
case 0x10ec0288: case 0x10ec0288:
case 0x10ec0298:
alc_process_coef_fw(codec, coef0288); alc_process_coef_fw(codec, coef0288);
break; break;
break; break;
...@@ -3801,6 +3804,9 @@ static void alc_headset_mode_ctia(struct hda_codec *codec) ...@@ -3801,6 +3804,9 @@ static void alc_headset_mode_ctia(struct hda_codec *codec)
case 0x10ec0283: case 0x10ec0283:
alc_process_coef_fw(codec, coef0233); alc_process_coef_fw(codec, coef0233);
break; break;
case 0x10ec0298:
alc_update_coef_idx(codec, 0x8e, 0x0070, 0x0020);/* Headset output enable */
/* ALC298 jack type setting is the same with ALC286/ALC288 */
case 0x10ec0286: case 0x10ec0286:
case 0x10ec0288: case 0x10ec0288:
alc_update_coef_idx(codec, 0x4f, 0xfcc0, 0xd400); alc_update_coef_idx(codec, 0x4f, 0xfcc0, 0xd400);
...@@ -3869,6 +3875,9 @@ static void alc_headset_mode_omtp(struct hda_codec *codec) ...@@ -3869,6 +3875,9 @@ static void alc_headset_mode_omtp(struct hda_codec *codec)
case 0x10ec0283: case 0x10ec0283:
alc_process_coef_fw(codec, coef0233); alc_process_coef_fw(codec, coef0233);
break; break;
case 0x10ec0298:
alc_update_coef_idx(codec, 0x8e, 0x0070, 0x0010);/* Headset output enable */
/* ALC298 jack type setting is the same with ALC286/ALC288 */
case 0x10ec0286: case 0x10ec0286:
case 0x10ec0288: case 0x10ec0288:
alc_update_coef_idx(codec, 0x4f, 0xfcc0, 0xe400); alc_update_coef_idx(codec, 0x4f, 0xfcc0, 0xe400);
...@@ -3931,6 +3940,9 @@ static void alc_determine_headset_type(struct hda_codec *codec) ...@@ -3931,6 +3940,9 @@ static void alc_determine_headset_type(struct hda_codec *codec)
val = alc_read_coef_idx(codec, 0x46); val = alc_read_coef_idx(codec, 0x46);
is_ctia = (val & 0x0070) == 0x0070; is_ctia = (val & 0x0070) == 0x0070;
break; break;
case 0x10ec0298:
alc_update_coef_idx(codec, 0x8e, 0x0070, 0x0020); /* Headset output enable */
/* ALC298 check jack type is the same with ALC286/ALC288 */
case 0x10ec0286: case 0x10ec0286:
case 0x10ec0288: case 0x10ec0288:
alc_process_coef_fw(codec, coef0288); alc_process_coef_fw(codec, coef0288);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment