Commit e8fbd250 authored by Kuninori Morimoto's avatar Kuninori Morimoto Committed by Mark Brown

ASoC: soc-core: self contained soc_unbind_aux_dev()

Current soc_unbind_aux_dev() implementation is very half,
thus it is very unreadable.

	for_each_comp_order(order) {
		for_each_card_auxs_safe(card, comp, _comp) {

(1)			if (comp->driver->remove_order == order) {
				...
=>				soc_unbind_aux_dev(comp);
			}
	}

soc_unbind_aux_dev() itself is not related to remove_order (1).
And, it is called from soc_remove_aux_devices(), even though
its paired function soc_bind_aux_dev() is called from
snd_soc_instantiate_card().
It is very unbalance, and very difficult to understand.

This patch do
1) update soc_bind_aux_dev() to self contained
2) call it from soc_cleanup_card_resources() to make up balance
Signed-off-by: default avatarKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Link: https://lore.kernel.org/r/87r24wor0z.wl-kuninori.morimoto.gx@renesas.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 4893a2eb
...@@ -1559,10 +1559,14 @@ static int soc_link_init(struct snd_soc_card *card, ...@@ -1559,10 +1559,14 @@ static int soc_link_init(struct snd_soc_card *card,
return ret; return ret;
} }
static void soc_unbind_aux_dev(struct snd_soc_component *component) static void soc_unbind_aux_dev(struct snd_soc_card *card)
{ {
component->init = NULL; struct snd_soc_component *component, *_component;
list_del(&component->card_aux_list);
for_each_card_auxs_safe(card, component, _component) {
component->init = NULL;
list_del(&component->card_aux_list);
}
} }
static int soc_bind_aux_dev(struct snd_soc_card *card) static int soc_bind_aux_dev(struct snd_soc_card *card)
...@@ -1614,12 +1618,8 @@ static void soc_remove_aux_devices(struct snd_soc_card *card) ...@@ -1614,12 +1618,8 @@ static void soc_remove_aux_devices(struct snd_soc_card *card)
for_each_comp_order(order) { for_each_comp_order(order) {
for_each_card_auxs_safe(card, comp, _comp) { for_each_card_auxs_safe(card, comp, _comp) {
if (comp->driver->remove_order == order)
if (comp->driver->remove_order == order) {
soc_remove_component(comp); soc_remove_component(comp);
/* remove it from the card's aux_comp_list */
soc_unbind_aux_dev(comp);
}
} }
} }
} }
...@@ -1932,6 +1932,7 @@ static void soc_cleanup_card_resources(struct snd_soc_card *card) ...@@ -1932,6 +1932,7 @@ static void soc_cleanup_card_resources(struct snd_soc_card *card)
/* remove auxiliary devices */ /* remove auxiliary devices */
soc_remove_aux_devices(card); soc_remove_aux_devices(card);
soc_unbind_aux_dev(card);
snd_soc_dapm_free(&card->dapm); snd_soc_dapm_free(&card->dapm);
soc_cleanup_card_debugfs(card); soc_cleanup_card_debugfs(card);
......
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