Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 741338f9 authored by Takashi Iwai's avatar Takashi Iwai Committed by Mark Brown
Browse files

ASoC: dapm: Fix ctl value accesses in a wrong type



snd_soc_dapm_dai_link_get() and _put() access the associated ctl
values as value.integer.value[].  However, this is an enum ctl, and it
has to be accessed via value.enumerated.item[].  The former is long
while the latter is unsigned int, so they don't align.

Fixes: c6615082 ('ASoC: dapm: add code to configure dai link parameters')
Cc: <stable@vger.kernel.org>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent 92e963f5
Loading
Loading
Loading
Loading
+4 −4
Original line number Original line Diff line number Diff line
@@ -3573,7 +3573,7 @@ static int snd_soc_dapm_dai_link_get(struct snd_kcontrol *kcontrol,
{
{
	struct snd_soc_dapm_widget *w = snd_kcontrol_chip(kcontrol);
	struct snd_soc_dapm_widget *w = snd_kcontrol_chip(kcontrol);


	ucontrol->value.integer.value[0] = w->params_select;
	ucontrol->value.enumerated.item[0] = w->params_select;


	return 0;
	return 0;
}
}
@@ -3587,13 +3587,13 @@ static int snd_soc_dapm_dai_link_put(struct snd_kcontrol *kcontrol,
	if (w->power)
	if (w->power)
		return -EBUSY;
		return -EBUSY;


	if (ucontrol->value.integer.value[0] == w->params_select)
	if (ucontrol->value.enumerated.item[0] == w->params_select)
		return 0;
		return 0;


	if (ucontrol->value.integer.value[0] >= w->num_params)
	if (ucontrol->value.enumerated.item[0] >= w->num_params)
		return -EINVAL;
		return -EINVAL;


	w->params_select = ucontrol->value.integer.value[0];
	w->params_select = ucontrol->value.enumerated.item[0];


	return 0;
	return 0;
}
}