aboutsummaryrefslogtreecommitdiffstats
path: root/sound/pci
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2007-08-22 18:31:43 -0400
committerJaroslav Kysela <perex@perex.cz>2007-10-16 09:59:25 -0400
commit0724ea2a85a804e151d960359b599ae8a7c1cad1 (patch)
tree4172262781ca6bc2dcf172bf392f867af78c1e39 /sound/pci
parent1fcaee6ee212fc214c1327d788afa10899c22e3a (diff)
[ALSA] hda-codec - Fix mater mixer switch of ALC262 sony-amd model
Fixed the master mixer switch of ALC272 sony-amd model. It used a simple bind-control, but it resulted in unexpected unmute of speaker output. Now the control checks the HP jack state apropriately, just like fujitsu model. Signed-off-by: Takashi Iwai <tiwai@suse.de> Signed-off-by: Jaroslav Kysela <perex@suse.cz>
Diffstat (limited to 'sound/pci')
-rw-r--r--sound/pci/hda/patch_realtek.c48
1 files changed, 38 insertions, 10 deletions
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c
index db29ebea20b5..4cbd0e6e849d 100644
--- a/sound/pci/hda/patch_realtek.c
+++ b/sound/pci/hda/patch_realtek.c
@@ -7453,18 +7453,46 @@ static struct snd_kcontrol_new alc262_HP_BPC_WildWest_option_mixer[] = {
7453 { } /* end */ 7453 { } /* end */
7454}; 7454};
7455 7455
7456static struct hda_bind_ctls alc262_sony_bind_sw = { 7456/* bind hp and internal speaker mute (with plug check) */
7457 .ops = &snd_hda_bind_sw, 7457static int alc262_sony_master_sw_put(struct snd_kcontrol *kcontrol,
7458 .values = { 7458 struct snd_ctl_elem_value *ucontrol)
7459 HDA_COMPOSE_AMP_VAL(0x15, 3, 0, HDA_OUTPUT), 7459{
7460 HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT), 7460 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
7461 0, 7461 long *valp = ucontrol->value.integer.value;
7462 }, 7462 int change;
7463}; 7463
7464 /* change hp mute */
7465 change = snd_hda_codec_amp_update(codec, 0x15, 0, HDA_OUTPUT, 0,
7466 HDA_AMP_MUTE,
7467 valp[0] ? 0 : HDA_AMP_MUTE);
7468 change |= snd_hda_codec_amp_update(codec, 0x15, 1, HDA_OUTPUT, 0,
7469 HDA_AMP_MUTE,
7470 valp[1] ? 0 : HDA_AMP_MUTE);
7471 if (change) {
7472 /* change speaker according to HP jack state */
7473 struct alc_spec *spec = codec->spec;
7474 unsigned int mute;
7475 if (spec->jack_present)
7476 mute = HDA_AMP_MUTE;
7477 else
7478 mute = snd_hda_codec_amp_read(codec, 0x15, 0,
7479 HDA_OUTPUT, 0);
7480 snd_hda_codec_amp_stereo(codec, 0x14, HDA_OUTPUT, 0,
7481 HDA_AMP_MUTE, mute);
7482 }
7483 return change;
7484}
7464 7485
7465static struct snd_kcontrol_new alc262_sony_mixer[] = { 7486static struct snd_kcontrol_new alc262_sony_mixer[] = {
7466 HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT), 7487 HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
7467 HDA_BIND_SW("Front Playback Switch", &alc262_sony_bind_sw), 7488 {
7489 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
7490 .name = "Master Playback Switch",
7491 .info = snd_hda_mixer_amp_switch_info,
7492 .get = snd_hda_mixer_amp_switch_get,
7493 .put = alc262_sony_master_sw_put,
7494 .private_value = HDA_COMPOSE_AMP_VAL(0x15, 3, 0, HDA_OUTPUT),
7495 },
7468 HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT), 7496 HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
7469 HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT), 7497 HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
7470 HDA_CODEC_VOLUME("ATAPI Mic Playback Volume", 0x0b, 0x01, HDA_INPUT), 7498 HDA_CODEC_VOLUME("ATAPI Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),