diff options
Diffstat (limited to 'sound/pci/hda/patch_realtek.c')
| -rw-r--r-- | sound/pci/hda/patch_realtek.c | 34 | 
1 files changed, 31 insertions, 3 deletions
| diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index b302d056e5d3..8cb14e27988b 100644 --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c @@ -3261,8 +3261,12 @@ static void alc269_fixup_mic_mute_hook(void *private_data, int enabled)  	pinval = snd_hda_codec_get_pin_target(codec, spec->mute_led_nid);  	pinval &= ~AC_PINCTL_VREFEN;  	pinval |= enabled ? AC_PINCTL_VREF_HIZ : AC_PINCTL_VREF_80; -	if (spec->mute_led_nid) +	if (spec->mute_led_nid) { +		/* temporarily power up/down for setting VREF */ +		snd_hda_power_up_pm(codec);  		snd_hda_set_pin_ctl_cache(codec, spec->mute_led_nid, pinval); +		snd_hda_power_down_pm(codec); +	}  }  /* Make sure the led works even in runtime suspend */ @@ -4722,6 +4726,16 @@ static void alc298_fixup_speaker_volume(struct hda_codec *codec,  	}  } +/* disable DAC3 (0x06) selection on NID 0x17 as it has no volume amp control */ +static void alc295_fixup_disable_dac3(struct hda_codec *codec, +				      const struct hda_fixup *fix, int action) +{ +	if (action == HDA_FIXUP_ACT_PRE_PROBE) { +		hda_nid_t conn[2] = { 0x02, 0x03 }; +		snd_hda_override_conn_list(codec, 0x17, 2, conn); +	} +} +  /* Hook to update amp GPIO4 for automute */  static void alc280_hp_gpio4_automute_hook(struct hda_codec *codec,  					  struct hda_jack_callback *jack) @@ -4871,6 +4885,7 @@ enum {  	ALC233_FIXUP_LENOVO_LINE2_MIC_HOTKEY,  	ALC255_FIXUP_DELL_SPK_NOISE,  	ALC225_FIXUP_DELL1_MIC_NO_PRESENCE, +	ALC295_FIXUP_DISABLE_DAC3,  	ALC280_FIXUP_HP_HEADSET_MIC,  	ALC221_FIXUP_HP_FRONT_MIC,  	ALC292_FIXUP_TPT460, @@ -5560,6 +5575,10 @@ static const struct hda_fixup alc269_fixups[] = {  		.chained = true,  		.chain_id = ALC298_FIXUP_DELL_AIO_MIC_NO_PRESENCE,  	}, +	[ALC295_FIXUP_DISABLE_DAC3] = { +		.type = HDA_FIXUP_FUNC, +		.v.func = alc295_fixup_disable_dac3, +	},  	[ALC256_FIXUP_DELL_INSPIRON_7559_SUBWOOFER] = {  		.type = HDA_FIXUP_PINS,  		.v.pins = (const struct hda_pintbl[]) { @@ -5617,6 +5636,7 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {  	SND_PCI_QUIRK(0x1028, 0x0725, "Dell Inspiron 3162", ALC255_FIXUP_DELL_SPK_NOISE),  	SND_PCI_QUIRK(0x1028, 0x075b, "Dell XPS 13 9360", ALC256_FIXUP_DELL_XPS_13_HEADPHONE_NOISE),  	SND_PCI_QUIRK(0x1028, 0x075d, "Dell AIO", ALC298_FIXUP_SPK_VOLUME), +	SND_PCI_QUIRK(0x1028, 0x07b0, "Dell Precision 7520", ALC295_FIXUP_DISABLE_DAC3),  	SND_PCI_QUIRK(0x1028, 0x0798, "Dell Inspiron 17 7000 Gaming", ALC256_FIXUP_DELL_INSPIRON_7559_SUBWOOFER),  	SND_PCI_QUIRK(0x1028, 0x082a, "Dell XPS 13 9360", ALC256_FIXUP_DELL_XPS_13_HEADPHONE_NOISE),  	SND_PCI_QUIRK(0x1028, 0x164a, "Dell", ALC293_FIXUP_DELL1_MIC_NO_PRESENCE), @@ -6701,6 +6721,7 @@ enum {  	ALC668_FIXUP_DELL_DISABLE_AAMIX,  	ALC668_FIXUP_DELL_XPS13,  	ALC662_FIXUP_ASUS_Nx50, +	ALC668_FIXUP_ASUS_Nx51_HEADSET_MODE,  	ALC668_FIXUP_ASUS_Nx51,  }; @@ -6948,14 +6969,21 @@ static const struct hda_fixup alc662_fixups[] = {  		.chained = true,  		.chain_id = ALC662_FIXUP_BASS_1A  	}, +	[ALC668_FIXUP_ASUS_Nx51_HEADSET_MODE] = { +		.type = HDA_FIXUP_FUNC, +		.v.func = alc_fixup_headset_mode_alc668, +		.chain_id = ALC662_FIXUP_BASS_CHMAP +	},  	[ALC668_FIXUP_ASUS_Nx51] = {  		.type = HDA_FIXUP_PINS,  		.v.pins = (const struct hda_pintbl[]) { -			{0x1a, 0x90170151}, /* bass speaker */ +			{ 0x19, 0x03a1913d }, /* use as headphone mic, without its own jack detect */ +			{ 0x1a, 0x90170151 }, /* bass speaker */ +			{ 0x1b, 0x03a1113c }, /* use as headset mic, without its own jack detect */  			{}  		},  		.chained = true, -		.chain_id = ALC662_FIXUP_BASS_CHMAP, +		.chain_id = ALC668_FIXUP_ASUS_Nx51_HEADSET_MODE,  	},  }; | 
