Commit 52ef6284 authored by Lars-Peter Clausen's avatar Lars-Peter Clausen Committed by Mark Brown

ASoC: ab8500-codec: Move control lock to the driver level

The ab8500 driver uses a driver specific lock to protect concurrent access
to some of the control put/get handlers and uses the snd_soc_codec mutex for
some others. This patch updates the driver to consistently use the driver
specific lock for all controls. This will allow us to eventually remove the
snd_soc_codec mutex.
Signed-off-by: default avatarLars-Peter Clausen <lars@metafoo.de>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent f114040e
...@@ -126,13 +126,13 @@ struct ab8500_codec_drvdata_dbg { ...@@ -126,13 +126,13 @@ struct ab8500_codec_drvdata_dbg {
/* Private data for AB8500 device-driver */ /* Private data for AB8500 device-driver */
struct ab8500_codec_drvdata { struct ab8500_codec_drvdata {
struct regmap *regmap; struct regmap *regmap;
struct mutex ctrl_lock;
/* Sidetone */ /* Sidetone */
long *sid_fir_values; long *sid_fir_values;
enum sid_state sid_status; enum sid_state sid_status;
/* ANC */ /* ANC */
struct mutex anc_lock;
long *anc_fir_values; long *anc_fir_values;
long *anc_iir_values; long *anc_iir_values;
enum anc_state anc_status; enum anc_state anc_status;
...@@ -1129,9 +1129,9 @@ static int sid_status_control_get(struct snd_kcontrol *kcontrol, ...@@ -1129,9 +1129,9 @@ static int sid_status_control_get(struct snd_kcontrol *kcontrol,
struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol); struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
struct ab8500_codec_drvdata *drvdata = dev_get_drvdata(codec->dev); struct ab8500_codec_drvdata *drvdata = dev_get_drvdata(codec->dev);
mutex_lock(&codec->mutex); mutex_lock(&drvdata->ctrl_lock);
ucontrol->value.integer.value[0] = drvdata->sid_status; ucontrol->value.integer.value[0] = drvdata->sid_status;
mutex_unlock(&codec->mutex); mutex_unlock(&drvdata->ctrl_lock);
return 0; return 0;
} }
...@@ -1154,7 +1154,7 @@ static int sid_status_control_put(struct snd_kcontrol *kcontrol, ...@@ -1154,7 +1154,7 @@ static int sid_status_control_put(struct snd_kcontrol *kcontrol,
return -EIO; return -EIO;
} }
mutex_lock(&codec->mutex); mutex_lock(&drvdata->ctrl_lock);
sidconf = snd_soc_read(codec, AB8500_SIDFIRCONF); sidconf = snd_soc_read(codec, AB8500_SIDFIRCONF);
if (((sidconf & BIT(AB8500_SIDFIRCONF_FIRSIDBUSY)) != 0)) { if (((sidconf & BIT(AB8500_SIDFIRCONF_FIRSIDBUSY)) != 0)) {
...@@ -1185,7 +1185,7 @@ static int sid_status_control_put(struct snd_kcontrol *kcontrol, ...@@ -1185,7 +1185,7 @@ static int sid_status_control_put(struct snd_kcontrol *kcontrol,
drvdata->sid_status = SID_FIR_CONFIGURED; drvdata->sid_status = SID_FIR_CONFIGURED;
out: out:
mutex_unlock(&codec->mutex); mutex_unlock(&drvdata->ctrl_lock);
dev_dbg(codec->dev, "%s: Exit\n", __func__); dev_dbg(codec->dev, "%s: Exit\n", __func__);
...@@ -1198,9 +1198,9 @@ static int anc_status_control_get(struct snd_kcontrol *kcontrol, ...@@ -1198,9 +1198,9 @@ static int anc_status_control_get(struct snd_kcontrol *kcontrol,
struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol); struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
struct ab8500_codec_drvdata *drvdata = dev_get_drvdata(codec->dev); struct ab8500_codec_drvdata *drvdata = dev_get_drvdata(codec->dev);
mutex_lock(&codec->mutex); mutex_lock(&drvdata->ctrl_lock);
ucontrol->value.integer.value[0] = drvdata->anc_status; ucontrol->value.integer.value[0] = drvdata->anc_status;
mutex_unlock(&codec->mutex); mutex_unlock(&drvdata->ctrl_lock);
return 0; return 0;
} }
...@@ -1217,7 +1217,7 @@ static int anc_status_control_put(struct snd_kcontrol *kcontrol, ...@@ -1217,7 +1217,7 @@ static int anc_status_control_put(struct snd_kcontrol *kcontrol,
dev_dbg(dev, "%s: Enter.\n", __func__); dev_dbg(dev, "%s: Enter.\n", __func__);
mutex_lock(&drvdata->anc_lock); mutex_lock(&drvdata->ctrl_lock);
req = ucontrol->value.integer.value[0]; req = ucontrol->value.integer.value[0];
if (req >= ARRAY_SIZE(enum_anc_state)) { if (req >= ARRAY_SIZE(enum_anc_state)) {
...@@ -1244,9 +1244,7 @@ static int anc_status_control_put(struct snd_kcontrol *kcontrol, ...@@ -1244,9 +1244,7 @@ static int anc_status_control_put(struct snd_kcontrol *kcontrol,
} }
snd_soc_dapm_sync(&codec->dapm); snd_soc_dapm_sync(&codec->dapm);
mutex_lock(&codec->mutex);
anc_configure(codec, apply_fir, apply_iir); anc_configure(codec, apply_fir, apply_iir);
mutex_unlock(&codec->mutex);
if (apply_fir) { if (apply_fir) {
if (drvdata->anc_status == ANC_IIR_CONFIGURED) if (drvdata->anc_status == ANC_IIR_CONFIGURED)
...@@ -1265,7 +1263,7 @@ static int anc_status_control_put(struct snd_kcontrol *kcontrol, ...@@ -1265,7 +1263,7 @@ static int anc_status_control_put(struct snd_kcontrol *kcontrol,
snd_soc_dapm_sync(&codec->dapm); snd_soc_dapm_sync(&codec->dapm);
cleanup: cleanup:
mutex_unlock(&drvdata->anc_lock); mutex_unlock(&drvdata->ctrl_lock);
if (status < 0) if (status < 0)
dev_err(dev, "%s: Unable to configure ANC! (status = %d)\n", dev_err(dev, "%s: Unable to configure ANC! (status = %d)\n",
...@@ -1294,14 +1292,15 @@ static int filter_control_get(struct snd_kcontrol *kcontrol, ...@@ -1294,14 +1292,15 @@ static int filter_control_get(struct snd_kcontrol *kcontrol,
struct snd_ctl_elem_value *ucontrol) struct snd_ctl_elem_value *ucontrol)
{ {
struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol); struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
struct ab8500_codec_drvdata *drvdata = snd_soc_codec_get_drvdata(codec);
struct filter_control *fc = struct filter_control *fc =
(struct filter_control *)kcontrol->private_value; (struct filter_control *)kcontrol->private_value;
unsigned int i; unsigned int i;
mutex_lock(&codec->mutex); mutex_lock(&drvdata->ctrl_lock);
for (i = 0; i < fc->count; i++) for (i = 0; i < fc->count; i++)
ucontrol->value.integer.value[i] = fc->value[i]; ucontrol->value.integer.value[i] = fc->value[i];
mutex_unlock(&codec->mutex); mutex_unlock(&drvdata->ctrl_lock);
return 0; return 0;
} }
...@@ -1310,14 +1309,15 @@ static int filter_control_put(struct snd_kcontrol *kcontrol, ...@@ -1310,14 +1309,15 @@ static int filter_control_put(struct snd_kcontrol *kcontrol,
struct snd_ctl_elem_value *ucontrol) struct snd_ctl_elem_value *ucontrol)
{ {
struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol); struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol);
struct ab8500_codec_drvdata *drvdata = snd_soc_codec_get_drvdata(codec);
struct filter_control *fc = struct filter_control *fc =
(struct filter_control *)kcontrol->private_value; (struct filter_control *)kcontrol->private_value;
unsigned int i; unsigned int i;
mutex_lock(&codec->mutex); mutex_lock(&drvdata->ctrl_lock);
for (i = 0; i < fc->count; i++) for (i = 0; i < fc->count; i++)
fc->value[i] = ucontrol->value.integer.value[i]; fc->value[i] = ucontrol->value.integer.value[i];
mutex_unlock(&codec->mutex); mutex_unlock(&drvdata->ctrl_lock);
return 0; return 0;
} }
...@@ -2545,7 +2545,7 @@ static int ab8500_codec_probe(struct snd_soc_codec *codec) ...@@ -2545,7 +2545,7 @@ static int ab8500_codec_probe(struct snd_soc_codec *codec)
(void)snd_soc_dapm_disable_pin(&codec->dapm, "ANC Configure Input"); (void)snd_soc_dapm_disable_pin(&codec->dapm, "ANC Configure Input");
mutex_init(&drvdata->anc_lock); mutex_init(&drvdata->ctrl_lock);
return status; return status;
} }
......
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