Commit c4a91e17 authored by Takashi Iwai's avatar Takashi Iwai

Merge branch 'for-linus' into for-next

parents 4308c9b0 c7cd0ef6
...@@ -3102,7 +3102,7 @@ static int add_std_chmaps(struct hda_codec *codec) ...@@ -3102,7 +3102,7 @@ static int add_std_chmaps(struct hda_codec *codec)
struct snd_pcm_chmap *chmap; struct snd_pcm_chmap *chmap;
const struct snd_pcm_chmap_elem *elem; const struct snd_pcm_chmap_elem *elem;
if (!pcm || pcm->own_chmap || if (!pcm || !pcm->pcm || pcm->own_chmap ||
!hinfo->substreams) !hinfo->substreams)
continue; continue;
elem = hinfo->chmap ? hinfo->chmap : snd_pcm_std_chmaps; elem = hinfo->chmap ? hinfo->chmap : snd_pcm_std_chmaps;
......
...@@ -671,7 +671,8 @@ static bool is_active_nid(struct hda_codec *codec, hda_nid_t nid, ...@@ -671,7 +671,8 @@ static bool is_active_nid(struct hda_codec *codec, hda_nid_t nid,
} }
for (i = 0; i < path->depth; i++) { for (i = 0; i < path->depth; i++) {
if (path->path[i] == nid) { if (path->path[i] == nid) {
if (dir == HDA_OUTPUT || path->idx[i] == idx) if (dir == HDA_OUTPUT || idx == -1 ||
path->idx[i] == idx)
return true; return true;
break; break;
} }
...@@ -682,7 +683,7 @@ static bool is_active_nid(struct hda_codec *codec, hda_nid_t nid, ...@@ -682,7 +683,7 @@ static bool is_active_nid(struct hda_codec *codec, hda_nid_t nid,
/* check whether the NID is referred by any active paths */ /* check whether the NID is referred by any active paths */
#define is_active_nid_for_any(codec, nid) \ #define is_active_nid_for_any(codec, nid) \
is_active_nid(codec, nid, HDA_OUTPUT, 0) is_active_nid(codec, nid, HDA_OUTPUT, -1)
/* get the default amp value for the target state */ /* get the default amp value for the target state */
static int get_amp_val_to_activate(struct hda_codec *codec, hda_nid_t nid, static int get_amp_val_to_activate(struct hda_codec *codec, hda_nid_t nid,
...@@ -883,8 +884,7 @@ void snd_hda_activate_path(struct hda_codec *codec, struct nid_path *path, ...@@ -883,8 +884,7 @@ void snd_hda_activate_path(struct hda_codec *codec, struct nid_path *path,
struct hda_gen_spec *spec = codec->spec; struct hda_gen_spec *spec = codec->spec;
int i; int i;
if (!enable) path->active = enable;
path->active = false;
/* make sure the widget is powered up */ /* make sure the widget is powered up */
if (enable && (spec->power_down_unused || codec->power_save_node)) if (enable && (spec->power_down_unused || codec->power_save_node))
...@@ -902,9 +902,6 @@ void snd_hda_activate_path(struct hda_codec *codec, struct nid_path *path, ...@@ -902,9 +902,6 @@ void snd_hda_activate_path(struct hda_codec *codec, struct nid_path *path,
if (has_amp_out(codec, path, i)) if (has_amp_out(codec, path, i))
activate_amp_out(codec, path, i, enable); activate_amp_out(codec, path, i, enable);
} }
if (enable)
path->active = true;
} }
EXPORT_SYMBOL_GPL(snd_hda_activate_path); EXPORT_SYMBOL_GPL(snd_hda_activate_path);
......
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