int num_all_dacs;
hda_nid_t all_dacs[16];
- /* output paths */
- struct snd_array out_path;
-
- /* input paths */
- struct snd_array in_path;
-
- /* analog loopback paths */
- struct snd_array loopback_path;
+ /* path list */
+ struct snd_array paths;
/* hooks */
void (*init_hook)(struct hda_codec *codec);
alc_free_kctls(codec);
alc_free_bind_ctls(codec);
- snd_array_free(&spec->out_path);
- snd_array_free(&spec->in_path);
- snd_array_free(&spec->loopback_path);
+ snd_array_free(&spec->paths);
snd_hda_gen_free(&spec->gen);
kfree(spec);
snd_hda_detach_beep_device(codec);
!nid_has_mute(codec, mix_nid, HDA_INPUT))
return 0; /* no need for analog loopback */
- path = snd_array_new(&spec->loopback_path);
+ path = snd_array_new(&spec->paths);
if (!path)
return -ENOMEM;
memset(path, 0, sizeof(*path));
struct hda_input_mux *imux = &spec->private_imux[0];
struct nid_path *path;
- path = snd_array_new(&spec->in_path);
+ path = snd_array_new(&spec->paths);
if (!path)
return -ENOMEM;
memset(path, 0, sizeof(*path));
struct alc_spec *spec = codec->spec;
int i;
- for (i = 0; i < spec->out_path.used; i++) {
- struct nid_path *path = snd_array_elem(&spec->out_path, i);
+ for (i = 0; i < spec->paths.used; i++) {
+ struct nid_path *path = snd_array_elem(&spec->paths, i);
if (path->path[0] == nid)
return true;
}
struct alc_spec *spec = codec->spec;
int i;
- for (i = 0; i < spec->out_path.used; i++) {
- struct nid_path *path = snd_array_elem(&spec->out_path, i);
+ for (i = 0; i < spec->paths.used; i++) {
+ struct nid_path *path = snd_array_elem(&spec->paths, i);
if (path->ctls[type] == val)
return true;
}
struct alc_spec *spec = codec->spec;
struct nid_path *path;
- path = snd_array_new(&spec->out_path);
+ path = snd_array_new(&spec->paths);
if (!path)
return false;
memset(path, 0, sizeof(*path));
if (parse_nid_path(codec, dac, pin, 0, path))
return true;
/* push back */
- spec->out_path.used--;
+ spec->paths.used--;
return false;
}
struct alc_spec *spec = codec->spec;
int i;
- for (i = 0; i < spec->out_path.used; i++) {
- struct nid_path *path = snd_array_elem(&spec->out_path, i);
+ for (i = 0; i < spec->paths.used; i++) {
+ struct nid_path *path = snd_array_elem(&spec->paths, i);
if (path->depth <= 0)
continue;
if ((!dac || path->path[0] == dac) &&
memset(spec->multiout.hp_out_nid, 0, sizeof(spec->multiout.hp_out_nid));
memset(spec->multiout.extra_out_nid, 0, sizeof(spec->multiout.extra_out_nid));
spec->multi_ios = 0;
- snd_array_free(&spec->out_path);
+ snd_array_free(&spec->paths);
badness = 0;
/* fill hard-wired DACs first */
"Speaker");
}
-static bool is_ctl_associated_in_list(struct snd_array *array, hda_nid_t nid,
- int dir, int idx, int types)
+/* check whether a control with the given (nid, dir, idx) was assigned */
+static bool is_ctl_associated(struct hda_codec *codec, hda_nid_t nid,
+ int dir, int idx)
{
+ struct alc_spec *spec = codec->spec;
int i, type;
- for (i = 0; i < array->used; i++) {
- struct nid_path *p = snd_array_elem(array, i);
+ for (i = 0; i < spec->paths.used; i++) {
+ struct nid_path *p = snd_array_elem(&spec->paths, i);
if (p->depth <= 0)
continue;
for (type = 0; type < 2; type++) {
- if (types & (1 << type)) {
- unsigned int val = p->ctls[type];
- if (get_amp_nid_(val) == nid &&
- get_amp_direction_(val) == dir &&
- get_amp_index_(val) == idx)
- return true;
- }
+ unsigned int val = p->ctls[type];
+ if (get_amp_nid_(val) == nid &&
+ get_amp_direction_(val) == dir &&
+ get_amp_index_(val) == idx)
+ return true;
}
}
return false;
}
-/* check whether a control with the given (nid, dir, idx) was assigned */
-static bool is_ctl_associated(struct hda_codec *codec, hda_nid_t nid,
- int dir, int idx)
-{
- struct alc_spec *spec = codec->spec;
- return is_ctl_associated_in_list(&spec->out_path, nid, dir, idx, 3) ||
- is_ctl_associated_in_list(&spec->in_path, nid, dir, idx, 3) ||
- is_ctl_associated_in_list(&spec->loopback_path, nid, dir, idx, 3);
-}
-
/* can have the amp-in capability? */
static bool has_amp_in(struct hda_codec *codec, struct nid_path *path, int idx)
{
return true;
}
-static bool is_active_in_list(struct hda_codec *codec, struct snd_array *array,
- hda_nid_t nid, int dir, int idx)
+/* check whether the given (nid,dir,idx) is active */
+static bool is_active_nid(struct hda_codec *codec, hda_nid_t nid,
+ unsigned int idx, unsigned int dir)
{
+ struct alc_spec *spec = codec->spec;
int i, n;
- for (n = 0; n < array->used; n++) {
- struct nid_path *path = snd_array_elem(array, n);
+ for (n = 0; n < spec->paths.used; n++) {
+ struct nid_path *path = snd_array_elem(&spec->paths, n);
if (!path->active)
continue;
for (i = 0; i < path->depth; i++) {
return false;
}
-/* check whether the given (nid,dir,idx) is active */
-static bool is_active_nid(struct hda_codec *codec, hda_nid_t nid,
- unsigned int idx, unsigned int dir)
-{
- struct alc_spec *spec = codec->spec;
- return is_active_in_list(codec, &spec->out_path, nid, idx, dir) ||
- is_active_in_list(codec, &spec->in_path, nid, idx, dir) ||
- is_active_in_list(codec, &spec->loopback_path, nid, idx, dir);
-}
-
/* get the default amp value for the target state */
static int get_amp_val_to_activate(struct hda_codec *codec, hda_nid_t nid,
int dir, bool enable)
}
if (!hardwired && spec->multi_ios < 2) {
/* cancel newly assigned paths */
- spec->out_path.used -= spec->multi_ios - old_pins;
+ spec->paths.used -= spec->multi_ios - old_pins;
spec->multi_ios = old_pins;
return badness;
}
snd_hda_gen_init(&spec->gen);
snd_array_init(&spec->kctls, sizeof(struct snd_kcontrol_new), 32);
snd_array_init(&spec->bind_ctls, sizeof(struct hda_bind_ctls *), 8);
- snd_array_init(&spec->out_path, sizeof(struct nid_path), 8);
- snd_array_init(&spec->in_path, sizeof(struct nid_path), 8);
- snd_array_init(&spec->loopback_path, sizeof(struct nid_path), 8);
+ snd_array_init(&spec->paths, sizeof(struct nid_path), 8);
err = alc_codec_rename_from_preset(codec);
if (err < 0) {