[alsa-devel] [PATCH 13/31] HDA patch_via.c: Refresh front playback mute if hp plug-in mutes speaker.
[ALSA] HDA VIA: Refresh front playback mute if hp plug-in mutes speaker.
Signed-off-by: Lydia Wang lydiawang@viatech.com.cn
Index: sound-2.6/sound/pci/hda/patch_via.c =================================================================== --- sound-2.6.orig/sound/pci/hda/patch_via.c 2009-10-05 15:10:13.000000000 +0800 +++ sound-2.6/sound/pci/hda/patch_via.c 2009-10-05 15:10:22.000000000 +0800 @@ -1346,14 +1346,26 @@ /* mute internal speaker if HP is plugged */ static void via_hp_automute(struct hda_codec *codec) { - unsigned int present; + unsigned int present = 0; struct via_spec *spec = codec->spec; + char name[32] = "Front Playback Switch";
present = snd_hda_codec_read(codec, spec->autocfg.hp_pins[0], 0, AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; - snd_hda_codec_amp_stereo(codec, spec->autocfg.line_out_pins[0], - HDA_OUTPUT, 0, HDA_AMP_MUTE, - present ? HDA_AMP_MUTE : 0); + + if (!spec->hp_independent_mode) { + struct snd_card *card = codec->bus->card; + struct snd_kcontrol *kctl; + /* auto mute */ + snd_hda_codec_amp_stereo( + codec, spec->autocfg.line_out_pins[0], HDA_OUTPUT, 0, + HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0); + /* notify change */ + list_for_each_entry(kctl, &card->controls, list) + if (strcmp(kctl->id.name, name) == 0) + snd_ctl_notify(card, SNDRV_CTL_EVENT_MASK_VALUE, + &kctl->id); + } }
static void via_gpio_control(struct hda_codec *codec)
At Mon, 5 Oct 2009 22:27:16 +0800, Li Bo wrote:
[ALSA] HDA VIA: Refresh front playback mute if hp plug-in mutes speaker.
Signed-off-by: Lydia Wang lydiawang@viatech.com.cn
Index: sound-2.6/sound/pci/hda/patch_via.c
--- sound-2.6.orig/sound/pci/hda/patch_via.c 2009-10-05 15:10:13.000000000 +0800 +++ sound-2.6/sound/pci/hda/patch_via.c 2009-10-05 15:10:22.000000000 +0800 @@ -1346,14 +1346,26 @@ /* mute internal speaker if HP is plugged */ static void via_hp_automute(struct hda_codec *codec) {
- unsigned int present;
- unsigned int present = 0; struct via_spec *spec = codec->spec;
- char name[32] = "Front Playback Switch";
Use a constant string, at least a form like: const char *name = "..."; But...
present = snd_hda_codec_read(codec, spec->autocfg.hp_pins[0], 0, AC_VERB_GET_PIN_SENSE, 0) & 0x80000000;
- snd_hda_codec_amp_stereo(codec, spec->autocfg.line_out_pins[0],
HDA_OUTPUT, 0, HDA_AMP_MUTE,
present ? HDA_AMP_MUTE : 0);
- if (!spec->hp_independent_mode) {
struct snd_card *card = codec->bus->card;
struct snd_kcontrol *kctl;
/* auto mute */
snd_hda_codec_amp_stereo(
codec, spec->autocfg.line_out_pins[0], HDA_OUTPUT, 0,
HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
/* notify change */
list_for_each_entry(kctl, &card->controls, list)
if (strcmp(kctl->id.name, name) == 0)
snd_ctl_notify(card, SNDRV_CTL_EVENT_MASK_VALUE,
&kctl->id);
Don't search for a kctl here. Just set up kctl->id, and let snd_ctl_notify() to search for the element.
Takashi
On Mon, Oct 5, 2009 at 11:08 PM, Takashi Iwai tiwai@suse.de wrote:
At Mon, 5 Oct 2009 22:27:16 +0800, Li Bo wrote:
[ALSA] HDA VIA: Refresh front playback mute if hp plug-in mutes speaker.
Signed-off-by: Lydia Wang lydiawang@viatech.com.cn
Index: sound-2.6/sound/pci/hda/patch_via.c
--- sound-2.6.orig/sound/pci/hda/patch_via.c 2009-10-05 15:10:13.000000000 +0800 +++ sound-2.6/sound/pci/hda/patch_via.c 2009-10-05 15:10:22.000000000 +0800 @@ -1346,14 +1346,26 @@ /* mute internal speaker if HP is plugged */ static void via_hp_automute(struct hda_codec *codec) {
- unsigned int present;
- unsigned int present = 0;
struct via_spec *spec = codec->spec;
- char name[32] = "Front Playback Switch";
Use a constant string, at least a form like: const char *name = "..."; But...
OK
present = snd_hda_codec_read(codec, spec->autocfg.hp_pins[0], 0, AC_VERB_GET_PIN_SENSE, 0) & 0x80000000;
- snd_hda_codec_amp_stereo(codec, spec->autocfg.line_out_pins[0],
- HDA_OUTPUT, 0, HDA_AMP_MUTE,
- present ? HDA_AMP_MUTE : 0);
- if (!spec->hp_independent_mode) {
- struct snd_card *card = codec->bus->card;
- struct snd_kcontrol *kctl;
- /* auto mute */
- snd_hda_codec_amp_stereo(
- codec, spec->autocfg.line_out_pins[0], HDA_OUTPUT, 0,
- HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
- /* notify change */
- list_for_each_entry(kctl, &card->controls, list)
- if (strcmp(kctl->id.name, name) == 0)
- snd_ctl_notify(card, SNDRV_CTL_EVENT_MASK_VALUE,
- &kctl->id);
Don't search for a kctl here. Just set up kctl->id, and let snd_ctl_notify() to search for the element.
I tried to setup kctl->id, but found that to setup it properly, we also need search. Maybe we have to search here?
Takashi
At Tue, 6 Oct 2009 13:10:54 +0800, Li Bo wrote:
On Mon, Oct 5, 2009 at 11:08 PM, Takashi Iwai tiwai@suse.de wrote:
At Mon, 5 Oct 2009 22:27:16 +0800, Li Bo wrote:
[ALSA] HDA VIA: Refresh front playback mute if hp plug-in mutes speaker.
Signed-off-by: Lydia Wang lydiawang@viatech.com.cn
Index: sound-2.6/sound/pci/hda/patch_via.c
--- sound-2.6.orig/sound/pci/hda/patch_via.c 2009-10-05 15:10:13.000000000 +0800 +++ sound-2.6/sound/pci/hda/patch_via.c 2009-10-05 15:10:22.000000000 +0800 @@ -1346,14 +1346,26 @@ /* mute internal speaker if HP is plugged */ static void via_hp_automute(struct hda_codec *codec) {
- unsigned int present;
- unsigned int present = 0;
struct via_spec *spec = codec->spec;
- char name[32] = "Front Playback Switch";
Use a constant string, at least a form like: const char *name = "..."; But...
OK
present = snd_hda_codec_read(codec, spec->autocfg.hp_pins[0], 0, AC_VERB_GET_PIN_SENSE, 0) & 0x80000000;
- snd_hda_codec_amp_stereo(codec, spec->autocfg.line_out_pins[0],
- HDA_OUTPUT, 0, HDA_AMP_MUTE,
- present ? HDA_AMP_MUTE : 0);
- if (!spec->hp_independent_mode) {
- struct snd_card *card = codec->bus->card;
- struct snd_kcontrol *kctl;
- /* auto mute */
- snd_hda_codec_amp_stereo(
- codec, spec->autocfg.line_out_pins[0], HDA_OUTPUT, 0,
- HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
- /* notify change */
- list_for_each_entry(kctl, &card->controls, list)
- if (strcmp(kctl->id.name, name) == 0)
- snd_ctl_notify(card, SNDRV_CTL_EVENT_MASK_VALUE,
- &kctl->id);
Don't search for a kctl here. Just set up kctl->id, and let snd_ctl_notify() to search for the element.
I tried to setup kctl->id, but found that to setup it properly, we also need search. Maybe we have to search here?
No, you just need to set up a control id struct, and call with it. Something like below:
struct snd_ctl_elem_id id; memset(&id, 0, sizeof(id)); id.iface = SNDRV_CTL_ELEM_IFACE_MIXER; strcpy(id.name, "Front Playback Switch"); snd_ctl_notify(card, SNDRV_CTL_ELEM_MASK_VALUE, &id);
Takashi
On Tue, Oct 6, 2009 at 1:52 PM, Takashi Iwai tiwai@suse.de wrote:
At Tue, 6 Oct 2009 13:10:54 +0800, Li Bo wrote:
On Mon, Oct 5, 2009 at 11:08 PM, Takashi Iwai tiwai@suse.de wrote:
At Mon, 5 Oct 2009 22:27:16 +0800, Li Bo wrote:
[ALSA] HDA VIA: Refresh front playback mute if hp plug-in mutes speaker.
Signed-off-by: Lydia Wang lydiawang@viatech.com.cn
Index: sound-2.6/sound/pci/hda/patch_via.c
--- sound-2.6.orig/sound/pci/hda/patch_via.c 2009-10-05 15:10:13.000000000 +0800 +++ sound-2.6/sound/pci/hda/patch_via.c 2009-10-05 15:10:22.000000000 +0800 @@ -1346,14 +1346,26 @@ /* mute internal speaker if HP is plugged */ static void via_hp_automute(struct hda_codec *codec) {
- unsigned int present;
- unsigned int present = 0;
struct via_spec *spec = codec->spec;
- char name[32] = "Front Playback Switch";
Use a constant string, at least a form like: const char *name = "..."; But...
OK
present = snd_hda_codec_read(codec, spec->autocfg.hp_pins[0], 0, AC_VERB_GET_PIN_SENSE, 0) & 0x80000000;
- snd_hda_codec_amp_stereo(codec, spec->autocfg.line_out_pins[0],
- HDA_OUTPUT, 0, HDA_AMP_MUTE,
- present ? HDA_AMP_MUTE : 0);
- if (!spec->hp_independent_mode) {
- struct snd_card *card = codec->bus->card;
- struct snd_kcontrol *kctl;
- /* auto mute */
- snd_hda_codec_amp_stereo(
- codec, spec->autocfg.line_out_pins[0], HDA_OUTPUT, 0,
- HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
- /* notify change */
- list_for_each_entry(kctl, &card->controls, list)
- if (strcmp(kctl->id.name, name) == 0)
- snd_ctl_notify(card, SNDRV_CTL_EVENT_MASK_VALUE,
- &kctl->id);
Don't search for a kctl here. Just set up kctl->id, and let snd_ctl_notify() to search for the element.
I tried to setup kctl->id, but found that to setup it properly, we also need search. Maybe we have to search here?
No, you just need to set up a control id struct, and call with it. Something like below:
struct snd_ctl_elem_id id; memset(&id, 0, sizeof(id)); id.iface = SNDRV_CTL_ELEM_IFACE_MIXER; strcpy(id.name, "Front Playback Switch"); snd_ctl_notify(card, SNDRV_CTL_ELEM_MASK_VALUE, &id);
Takashi
Good, it works just fine:)
[ALSA] HDA VIA: Refresh front playback mute if hp plug-in mutes speaker.
Signed-off-by: Lydia Wang lydiawang@viatech.com.cn
--- sound/pci/hda/patch_via.c | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-)
--- a/sound/pci/hda/patch_via.c +++ b/sound/pci/hda/patch_via.c @@ -1351,14 +1351,25 @@ /* mute internal speaker if HP is plugged */ static void via_hp_automute(struct hda_codec *codec) { - unsigned int present; + unsigned int present = 0; struct via_spec *spec = codec->spec;
present = snd_hda_codec_read(codec, spec->autocfg.hp_pins[0], 0, AC_VERB_GET_PIN_SENSE, 0) & 0x80000000; - snd_hda_codec_amp_stereo(codec, spec->autocfg.line_out_pins[0], - HDA_OUTPUT, 0, HDA_AMP_MUTE, - present ? HDA_AMP_MUTE : 0); + + if (!spec->hp_independent_mode) { + struct snd_ctl_elem_id id; + /* auto mute */ + snd_hda_codec_amp_stereo( + codec, spec->autocfg.line_out_pins[0], HDA_OUTPUT, 0, + HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0); + /* notify change */ + memset(&id, 0, sizeof(id)); + id.iface = SNDRV_CTL_ELEM_IFACE_MIXER; + strcpy(id.name, "Front Playback Switch"); + snd_ctl_notify(codec->bus->card, SNDRV_CTL_EVENT_MASK_VALUE, + &id); + } }
static void via_gpio_control(struct hda_codec *codec)
participants (2)
-
Li Bo
-
Takashi Iwai