ASoC: Fix DAPM sync for TLV320AIC3x custom DAPM widget
We really should be doing this in the core, not in a driver... Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com> Tested-by: Jarkko Nikula <jarkko.nikula@bitmer.com>
This commit is contained in:
Родитель
3ebb5c9b10
Коммит
25c77c5fae
|
@ -381,6 +381,9 @@ int snd_soc_dapm_force_enable_pin(struct snd_soc_dapm_context *dapm,
|
||||||
int snd_soc_dapm_ignore_suspend(struct snd_soc_dapm_context *dapm,
|
int snd_soc_dapm_ignore_suspend(struct snd_soc_dapm_context *dapm,
|
||||||
const char *pin);
|
const char *pin);
|
||||||
|
|
||||||
|
/* Mostly internal - should not normally be used */
|
||||||
|
void dapm_mark_dirty(struct snd_soc_dapm_widget *w, const char *reason);
|
||||||
|
|
||||||
/* dapm widget types */
|
/* dapm widget types */
|
||||||
enum snd_soc_dapm_type {
|
enum snd_soc_dapm_type {
|
||||||
snd_soc_dapm_input = 0, /* input pin */
|
snd_soc_dapm_input = 0, /* input pin */
|
||||||
|
|
|
@ -197,6 +197,10 @@ static int snd_soc_dapm_put_volsw_aic3x(struct snd_kcontrol *kcontrol,
|
||||||
else
|
else
|
||||||
/* old connection must be powered down */
|
/* old connection must be powered down */
|
||||||
path->connect = invert ? 1 : 0;
|
path->connect = invert ? 1 : 0;
|
||||||
|
|
||||||
|
dapm_mark_dirty(path->source, "tlv320aic3x source");
|
||||||
|
dapm_mark_dirty(path->sink, "tlv320aic3x sink");
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -124,7 +124,7 @@ static bool dapm_dirty_widget(struct snd_soc_dapm_widget *w)
|
||||||
return !list_empty(&w->dirty);
|
return !list_empty(&w->dirty);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void dapm_mark_dirty(struct snd_soc_dapm_widget *w, const char *reason)
|
void dapm_mark_dirty(struct snd_soc_dapm_widget *w, const char *reason)
|
||||||
{
|
{
|
||||||
if (!dapm_dirty_widget(w)) {
|
if (!dapm_dirty_widget(w)) {
|
||||||
dev_vdbg(w->dapm->dev, "Marking %s dirty due to %s\n",
|
dev_vdbg(w->dapm->dev, "Marking %s dirty due to %s\n",
|
||||||
|
@ -132,6 +132,7 @@ static void dapm_mark_dirty(struct snd_soc_dapm_widget *w, const char *reason)
|
||||||
list_add_tail(&w->dirty, &w->dapm->card->dapm_dirty);
|
list_add_tail(&w->dirty, &w->dapm->card->dapm_dirty);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(dapm_mark_dirty);
|
||||||
|
|
||||||
/* create a new dapm widget */
|
/* create a new dapm widget */
|
||||||
static inline struct snd_soc_dapm_widget *dapm_cnew_widget(
|
static inline struct snd_soc_dapm_widget *dapm_cnew_widget(
|
||||||
|
|
Загрузка…
Ссылка в новой задаче