Commit 61aca564 authored by Lars-Peter Clausen's avatar Lars-Peter Clausen Committed by Mark Brown

ASoC: Add component level probe/remove support

Now that we have a unified probe and remove path make sure to call them for all
components. soc_{probe,remove}_component are responsible for setting up the DAPM
context for the component, initialize the component prefix, manage the debugfs
entries as well as do the registration of table based controls and DAPM
elements. They also call the component drivers probe and remove callbacks. This
patch makes these things available for generic snd_soc_component drivers rather
than only having them for snd_soc_codec and snd_soc_platform drivers.
Signed-off-by: default avatarLars-Peter Clausen <lars@metafoo.de>
Signed-off-by: default avatarMark Brown <broonie@linaro.org>
parent 93c3ce76
...@@ -690,6 +690,17 @@ struct snd_soc_compr_ops { ...@@ -690,6 +690,17 @@ struct snd_soc_compr_ops {
struct snd_soc_component_driver { struct snd_soc_component_driver {
const char *name; const char *name;
/* Default control and setup, added after probe() is run */
const struct snd_kcontrol_new *controls;
unsigned int num_controls;
const struct snd_soc_dapm_widget *dapm_widgets;
unsigned int num_dapm_widgets;
const struct snd_soc_dapm_route *dapm_routes;
unsigned int num_dapm_routes;
int (*probe)(struct snd_soc_component *);
void (*remove)(struct snd_soc_component *);
/* DT */ /* DT */
int (*of_xlate_dai_name)(struct snd_soc_component *component, int (*of_xlate_dai_name)(struct snd_soc_component *component,
struct of_phandle_args *args, struct of_phandle_args *args,
......
...@@ -1058,7 +1058,7 @@ static void soc_remove_link_components(struct snd_soc_card *card, int num, ...@@ -1058,7 +1058,7 @@ static void soc_remove_link_components(struct snd_soc_card *card, int num,
struct snd_soc_pcm_runtime *rtd = &card->rtd[num]; struct snd_soc_pcm_runtime *rtd = &card->rtd[num];
struct snd_soc_dai *cpu_dai = rtd->cpu_dai; struct snd_soc_dai *cpu_dai = rtd->cpu_dai;
struct snd_soc_platform *platform = rtd->platform; struct snd_soc_platform *platform = rtd->platform;
struct snd_soc_codec *codec; struct snd_soc_component *component;
int i; int i;
/* remove the platform */ /* remove the platform */
...@@ -1068,18 +1068,17 @@ static void soc_remove_link_components(struct snd_soc_card *card, int num, ...@@ -1068,18 +1068,17 @@ static void soc_remove_link_components(struct snd_soc_card *card, int num,
/* remove the CODEC-side CODEC */ /* remove the CODEC-side CODEC */
for (i = 0; i < rtd->num_codecs; i++) { for (i = 0; i < rtd->num_codecs; i++) {
codec = rtd->codec_dais[i]->codec; component = rtd->codec_dais[i]->component;
if (codec && codec->component.probed && if (component->probed &&
codec->component.driver->remove_order == order) component->driver->remove_order == order)
soc_remove_component(&codec->component); soc_remove_component(component);
} }
/* remove any CPU-side CODEC */ /* remove any CPU-side CODEC */
if (cpu_dai) { if (cpu_dai) {
codec = cpu_dai->codec; if (cpu_dai->component->probed &&
if (codec && codec->component.probed && cpu_dai->component->driver->remove_order == order)
codec->component.driver->remove_order == order) soc_remove_component(cpu_dai->component);
soc_remove_component(&codec->component);
} }
} }
...@@ -1289,19 +1288,17 @@ static int soc_probe_link_components(struct snd_soc_card *card, int num, ...@@ -1289,19 +1288,17 @@ static int soc_probe_link_components(struct snd_soc_card *card, int num,
int i, ret; int i, ret;
/* probe the CPU-side component, if it is a CODEC */ /* probe the CPU-side component, if it is a CODEC */
if (rtd->cpu_dai->codec) { component = rtd->cpu_dai->component;
component = &rtd->cpu_dai->codec->component; if (!component->probed &&
if (!component->probed && component->driver->probe_order == order) {
component->driver->probe_order == order) { ret = soc_probe_component(card, component);
ret = soc_probe_component(card, component); if (ret < 0)
if (ret < 0) return ret;
return ret;
}
} }
/* probe the CODEC-side components */ /* probe the CODEC-side components */
for (i = 0; i < rtd->num_codecs; i++) { for (i = 0; i < rtd->num_codecs; i++) {
component = &rtd->codec_dais[i]->codec->component; component = rtd->codec_dais[i]->component;
if (!component->probed && if (!component->probed &&
component->driver->probe_order == order) { component->driver->probe_order == order) {
ret = soc_probe_component(card, component); ret = soc_probe_component(card, component);
...@@ -4042,6 +4039,8 @@ static int snd_soc_component_initialize(struct snd_soc_component *component, ...@@ -4042,6 +4039,8 @@ static int snd_soc_component_initialize(struct snd_soc_component *component,
component->dev = dev; component->dev = dev;
component->driver = driver; component->driver = driver;
component->probe = component->driver->probe;
component->remove = component->driver->remove;
if (!component->dapm_ptr) if (!component->dapm_ptr)
component->dapm_ptr = &component->dapm; component->dapm_ptr = &component->dapm;
...@@ -4055,6 +4054,13 @@ static int snd_soc_component_initialize(struct snd_soc_component *component, ...@@ -4055,6 +4054,13 @@ static int snd_soc_component_initialize(struct snd_soc_component *component,
if (driver->stream_event) if (driver->stream_event)
dapm->stream_event = snd_soc_component_stream_event; dapm->stream_event = snd_soc_component_stream_event;
component->controls = driver->controls;
component->num_controls = driver->num_controls;
component->dapm_widgets = driver->dapm_widgets;
component->num_dapm_widgets = driver->num_dapm_widgets;
component->dapm_routes = driver->dapm_routes;
component->num_dapm_routes = driver->num_dapm_routes;
INIT_LIST_HEAD(&component->dai_list); INIT_LIST_HEAD(&component->dai_list);
mutex_init(&component->io_mutex); mutex_init(&component->io_mutex);
......
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