Commit 51e19ca5 authored by Takashi Iwai's avatar Takashi Iwai

ALSA: hda/conexant - Clean up beep code

Like the previous commit for Realtek codec, the similar cleanup work
can be applied to Conexant codec, too.  A slight difference is that
the call of cx_auto_parse_beep() is moved after
snd_hda_gen_parse_auto_config().  It's not strictly needed, but it'd
be good to make the creation of such beep mixers at the end, which
matches with the former situation.

Along with this conversion, cx_auto_build_controls() becomes just
calling snd_hda_gen_build_controls(), so it's simply replaced with
snd_hda_gen_build_controls.
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent fea80fae
...@@ -37,8 +37,6 @@ ...@@ -37,8 +37,6 @@
struct conexant_spec { struct conexant_spec {
struct hda_gen_spec gen; struct hda_gen_spec gen;
unsigned int beep_amp;
/* extra EAPD pins */ /* extra EAPD pins */
unsigned int num_eapds; unsigned int num_eapds;
hda_nid_t eapds[4]; hda_nid_t eapds[4];
...@@ -62,65 +60,48 @@ struct conexant_spec { ...@@ -62,65 +60,48 @@ struct conexant_spec {
#ifdef CONFIG_SND_HDA_INPUT_BEEP #ifdef CONFIG_SND_HDA_INPUT_BEEP
static inline void set_beep_amp(struct conexant_spec *spec, hda_nid_t nid, /* additional beep mixers; private_value will be overwritten */
int idx, int dir)
{
spec->gen.beep_nid = nid;
spec->beep_amp = HDA_COMPOSE_AMP_VAL(nid, 1, idx, dir);
}
/* additional beep mixers; the actual parameters are overwritten at build */
static const struct snd_kcontrol_new cxt_beep_mixer[] = { static const struct snd_kcontrol_new cxt_beep_mixer[] = {
HDA_CODEC_VOLUME_MONO("Beep Playback Volume", 0, 1, 0, HDA_OUTPUT), HDA_CODEC_VOLUME_MONO("Beep Playback Volume", 0, 1, 0, HDA_OUTPUT),
HDA_CODEC_MUTE_BEEP_MONO("Beep Playback Switch", 0, 1, 0, HDA_OUTPUT), HDA_CODEC_MUTE_BEEP_MONO("Beep Playback Switch", 0, 1, 0, HDA_OUTPUT),
{ } /* end */
}; };
/* create beep controls if needed */ static int set_beep_amp(struct conexant_spec *spec, hda_nid_t nid,
static int add_beep_ctls(struct hda_codec *codec) int idx, int dir)
{ {
struct conexant_spec *spec = codec->spec; struct snd_kcontrol_new *knew;
int err; unsigned int beep_amp = HDA_COMPOSE_AMP_VAL(nid, 1, idx, dir);
int i;
if (spec->beep_amp) { spec->gen.beep_nid = nid;
const struct snd_kcontrol_new *knew; for (i = 0; i < ARRAY_SIZE(cxt_beep_mixer); i++) {
for (knew = cxt_beep_mixer; knew->name; knew++) { knew = snd_hda_gen_add_kctl(&spec->gen, NULL,
struct snd_kcontrol *kctl; &cxt_beep_mixer[i]);
kctl = snd_ctl_new1(knew, codec); if (!knew)
if (!kctl)
return -ENOMEM; return -ENOMEM;
kctl->private_value = spec->beep_amp; knew->private_value = beep_amp;
err = snd_hda_ctl_add(codec, 0, kctl);
if (err < 0)
return err;
}
} }
return 0; return 0;
} }
#else
#define set_beep_amp(spec, nid, idx, dir) /* NOP */
#define add_beep_ctls(codec) 0
#endif
/*
* Automatic parser for CX20641 & co
*/
#ifdef CONFIG_SND_HDA_INPUT_BEEP static int cx_auto_parse_beep(struct hda_codec *codec)
static void cx_auto_parse_beep(struct hda_codec *codec)
{ {
struct conexant_spec *spec = codec->spec; struct conexant_spec *spec = codec->spec;
hda_nid_t nid; hda_nid_t nid;
for_each_hda_codec_node(nid, codec) for_each_hda_codec_node(nid, codec)
if (get_wcaps_type(get_wcaps(codec, nid)) == AC_WID_BEEP) { if (get_wcaps_type(get_wcaps(codec, nid)) == AC_WID_BEEP)
set_beep_amp(spec, nid, 0, HDA_OUTPUT); return set_beep_amp(spec, nid, 0, HDA_OUTPUT);
break; return 0;
}
} }
#else #else
#define cx_auto_parse_beep(codec) #define cx_auto_parse_beep(codec) 0
#endif #endif
/*
* Automatic parser for CX20641 & co
*/
/* parse EAPDs */ /* parse EAPDs */
static void cx_auto_parse_eapd(struct hda_codec *codec) static void cx_auto_parse_eapd(struct hda_codec *codec)
{ {
...@@ -179,21 +160,6 @@ static void cx_auto_vmaster_hook_mute_led(void *private_data, int enabled) ...@@ -179,21 +160,6 @@ static void cx_auto_vmaster_hook_mute_led(void *private_data, int enabled)
enabled ? 0x00 : 0x02); enabled ? 0x00 : 0x02);
} }
static int cx_auto_build_controls(struct hda_codec *codec)
{
int err;
err = snd_hda_gen_build_controls(codec);
if (err < 0)
return err;
err = add_beep_ctls(codec);
if (err < 0)
return err;
return 0;
}
static int cx_auto_init(struct hda_codec *codec) static int cx_auto_init(struct hda_codec *codec)
{ {
struct conexant_spec *spec = codec->spec; struct conexant_spec *spec = codec->spec;
...@@ -234,7 +200,7 @@ static void cx_auto_free(struct hda_codec *codec) ...@@ -234,7 +200,7 @@ static void cx_auto_free(struct hda_codec *codec)
} }
static const struct hda_codec_ops cx_auto_patch_ops = { static const struct hda_codec_ops cx_auto_patch_ops = {
.build_controls = cx_auto_build_controls, .build_controls = snd_hda_gen_build_controls,
.build_pcms = snd_hda_gen_build_pcms, .build_pcms = snd_hda_gen_build_pcms,
.init = cx_auto_init, .init = cx_auto_init,
.reboot_notify = cx_auto_reboot_notify, .reboot_notify = cx_auto_reboot_notify,
...@@ -1033,7 +999,6 @@ static int patch_conexant_auto(struct hda_codec *codec) ...@@ -1033,7 +999,6 @@ static int patch_conexant_auto(struct hda_codec *codec)
codec->spec = spec; codec->spec = spec;
codec->patch_ops = cx_auto_patch_ops; codec->patch_ops = cx_auto_patch_ops;
cx_auto_parse_beep(codec);
cx_auto_parse_eapd(codec); cx_auto_parse_eapd(codec);
spec->gen.own_eapd_ctl = 1; spec->gen.own_eapd_ctl = 1;
if (spec->dynamic_eapd) if (spec->dynamic_eapd)
...@@ -1093,6 +1058,10 @@ static int patch_conexant_auto(struct hda_codec *codec) ...@@ -1093,6 +1058,10 @@ static int patch_conexant_auto(struct hda_codec *codec)
if (err < 0) if (err < 0)
goto error; goto error;
err = cx_auto_parse_beep(codec);
if (err < 0)
goto error;
/* Some laptops with Conexant chips show stalls in S3 resume, /* Some laptops with Conexant chips show stalls in S3 resume,
* which falls into the single-cmd mode. * which falls into the single-cmd mode.
* Better to make reset, then. * Better to make reset, then.
......
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