ASoC: wm_adsp: Make DSP preloader a supply widget
Currently the DSP loading is split into two widgets, the preloader that is a snd_soc_dapm_dai_link widget which starts a thread to download the firmware, and the DSP itself which is a snd_soc_dapm_out_drv and synchronises the thread back in to the DAPM sequence. This allows the firmware download to be overlapped with the rest of the path bring up. The use of a snd_soc_dapm_dai_link widget requires the preloader to be part of the audio path in DAPM, really a supply widget is a better fit for the preloader. The preloader is something that needs to be done for the DSP to function, not a part of the audio path itself. This change makes the DSP preloader widget a supply widget, which as well as probably being a better fit will also make it much simpler to power up the preloader widget to trigger firmware download to the core independently of the audio path coming up. Signed-off-by: Charles Keepax <ckeepax@opensource.wolfsonmicro.com> Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
3577357a16
commit
5ca7e170e3
|
@ -191,20 +191,20 @@ extern unsigned int arizona_mixer_values[ARIZONA_NUM_MIXER_INPUTS];
|
||||||
#define ARIZONA_DSP_ROUTES(name) \
|
#define ARIZONA_DSP_ROUTES(name) \
|
||||||
{ name, NULL, name " Preloader"}, \
|
{ name, NULL, name " Preloader"}, \
|
||||||
{ name " Preloader", NULL, "SYSCLK" }, \
|
{ name " Preloader", NULL, "SYSCLK" }, \
|
||||||
{ name " Preloader", NULL, name " Aux 1" }, \
|
{ name, NULL, name " Aux 1" }, \
|
||||||
{ name " Preloader", NULL, name " Aux 2" }, \
|
{ name, NULL, name " Aux 2" }, \
|
||||||
{ name " Preloader", NULL, name " Aux 3" }, \
|
{ name, NULL, name " Aux 3" }, \
|
||||||
{ name " Preloader", NULL, name " Aux 4" }, \
|
{ name, NULL, name " Aux 4" }, \
|
||||||
{ name " Preloader", NULL, name " Aux 5" }, \
|
{ name, NULL, name " Aux 5" }, \
|
||||||
{ name " Preloader", NULL, name " Aux 6" }, \
|
{ name, NULL, name " Aux 6" }, \
|
||||||
ARIZONA_MIXER_INPUT_ROUTES(name " Aux 1"), \
|
ARIZONA_MIXER_INPUT_ROUTES(name " Aux 1"), \
|
||||||
ARIZONA_MIXER_INPUT_ROUTES(name " Aux 2"), \
|
ARIZONA_MIXER_INPUT_ROUTES(name " Aux 2"), \
|
||||||
ARIZONA_MIXER_INPUT_ROUTES(name " Aux 3"), \
|
ARIZONA_MIXER_INPUT_ROUTES(name " Aux 3"), \
|
||||||
ARIZONA_MIXER_INPUT_ROUTES(name " Aux 4"), \
|
ARIZONA_MIXER_INPUT_ROUTES(name " Aux 4"), \
|
||||||
ARIZONA_MIXER_INPUT_ROUTES(name " Aux 5"), \
|
ARIZONA_MIXER_INPUT_ROUTES(name " Aux 5"), \
|
||||||
ARIZONA_MIXER_INPUT_ROUTES(name " Aux 6"), \
|
ARIZONA_MIXER_INPUT_ROUTES(name " Aux 6"), \
|
||||||
ARIZONA_MIXER_ROUTES(name " Preloader", name "L"), \
|
ARIZONA_MIXER_ROUTES(name, name "L"), \
|
||||||
ARIZONA_MIXER_ROUTES(name " Preloader", name "R")
|
ARIZONA_MIXER_ROUTES(name, name "R")
|
||||||
|
|
||||||
#define ARIZONA_EQ_CONTROL(xname, xbase) \
|
#define ARIZONA_EQ_CONTROL(xname, xbase) \
|
||||||
{ .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, \
|
{ .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, \
|
||||||
|
|
|
@ -87,9 +87,10 @@ struct wm_adsp {
|
||||||
wm_adsp1_event, SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD)
|
wm_adsp1_event, SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD)
|
||||||
|
|
||||||
#define WM_ADSP2(wname, num, event_fn) \
|
#define WM_ADSP2(wname, num, event_fn) \
|
||||||
{ .id = snd_soc_dapm_dai_link, .name = wname " Preloader", \
|
{ .id = snd_soc_dapm_supply, .name = wname " Preloader", \
|
||||||
.reg = SND_SOC_NOPM, .shift = num, .event = event_fn, \
|
.reg = SND_SOC_NOPM, .shift = num, .event = event_fn, \
|
||||||
.event_flags = SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD }, \
|
.event_flags = SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD, \
|
||||||
|
.subseq = 100, /* Ensure we run after SYSCLK supply widget */ }, \
|
||||||
{ .id = snd_soc_dapm_out_drv, .name = wname, \
|
{ .id = snd_soc_dapm_out_drv, .name = wname, \
|
||||||
.reg = SND_SOC_NOPM, .shift = num, .event = wm_adsp2_event, \
|
.reg = SND_SOC_NOPM, .shift = num, .event = wm_adsp2_event, \
|
||||||
.event_flags = SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD }
|
.event_flags = SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD }
|
||||||
|
|
Loading…
Reference in New Issue