summaryrefslogtreecommitdiff
path: root/sound/soc/soc-core.c
diff options
context:
space:
mode:
authorKuninori Morimoto <kuninori.morimoto.gx@renesas.com>2017-08-07 02:06:40 +0000
committerMark Brown <broonie@kernel.org>2017-08-07 16:49:36 +0100
commit21a035287e28ec225fe7dfd1fffc509efd26a5db (patch)
treec897f502b0feb19a10d004e03d679372e3b0ae53 /sound/soc/soc-core.c
parentcf9e829eaf0195e722bc3a3929002a3fbe74dafa (diff)
ASoC: soc-core: remove duplicate mutex_unlock from snd_soc_unregister_component()
Current snd_soc_unregister_component() is using multiple mutex_unlock() for found/non-found cases. But it is unreadable and confusable code. This patch tidyup current code to be readable. Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com> Signed-off-by: Mark Brown <broonie@kernel.org>
Diffstat (limited to 'sound/soc/soc-core.c')
-rw-r--r--sound/soc/soc-core.c22
1 files changed, 13 insertions, 9 deletions
diff --git a/sound/soc/soc-core.c b/sound/soc/soc-core.c
index b21488972198..3bb8c63564cf 100644
--- a/sound/soc/soc-core.c
+++ b/sound/soc/soc-core.c
@@ -3328,21 +3328,25 @@ EXPORT_SYMBOL_GPL(snd_soc_register_component);
void snd_soc_unregister_component(struct device *dev)
{
struct snd_soc_component *component;
+ int found = 0;
mutex_lock(&client_mutex);
list_for_each_entry(component, &component_list, list) {
- if (dev == component->dev && component->registered_as_component)
- goto found;
+ if (dev != component->dev ||
+ !component->registered_as_component)
+ continue;
+
+ snd_soc_tplg_component_remove(component, SND_SOC_TPLG_INDEX_ALL);
+ snd_soc_component_del_unlocked(component);
+ found = 1;
+ break;
}
mutex_unlock(&client_mutex);
- return;
-found:
- snd_soc_tplg_component_remove(component, SND_SOC_TPLG_INDEX_ALL);
- snd_soc_component_del_unlocked(component);
- mutex_unlock(&client_mutex);
- snd_soc_component_cleanup(component);
- kfree(component);
+ if (found) {
+ snd_soc_component_cleanup(component);
+ kfree(component);
+ }
}
EXPORT_SYMBOL_GPL(snd_soc_unregister_component);