|
@@ -181,6 +181,10 @@ int dpcm_dapm_stream_event(struct snd_soc_pcm_runtime *fe, int dir,
|
|
|
dev_dbg(be->dev, "ASoC: BE %s event %d dir %d\n",
|
|
|
be->dai_link->name, event, dir);
|
|
|
|
|
|
+ if ((event == SND_SOC_DAPM_STREAM_STOP) &&
|
|
|
+ (be->dpcm[dir].users >= 1))
|
|
|
+ continue;
|
|
|
+
|
|
|
snd_soc_dapm_stream_event(be, dir, event);
|
|
|
}
|
|
|
|
|
@@ -2628,25 +2632,12 @@ static int dpcm_fe_dai_close(struct snd_pcm_substream *fe_substream)
|
|
|
return ret;
|
|
|
}
|
|
|
|
|
|
-static void soc_pcm_free(struct snd_pcm *pcm)
|
|
|
-{
|
|
|
- struct snd_soc_pcm_runtime *rtd = pcm->private_data;
|
|
|
- struct snd_soc_component *component;
|
|
|
-
|
|
|
- list_for_each_entry(component, &rtd->card->component_dev_list,
|
|
|
- card_list) {
|
|
|
- if (component->pcm_free)
|
|
|
- component->pcm_free(pcm);
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
/* create a new pcm */
|
|
|
int soc_new_pcm(struct snd_soc_pcm_runtime *rtd, int num)
|
|
|
{
|
|
|
struct snd_soc_platform *platform = rtd->platform;
|
|
|
struct snd_soc_dai *codec_dai;
|
|
|
struct snd_soc_dai *cpu_dai = rtd->cpu_dai;
|
|
|
- struct snd_soc_component *component;
|
|
|
struct snd_pcm *pcm;
|
|
|
char new_name[64];
|
|
|
int ret = 0, playback = 0, capture = 0;
|
|
@@ -2756,18 +2747,17 @@ int soc_new_pcm(struct snd_soc_pcm_runtime *rtd, int num)
|
|
|
if (capture)
|
|
|
snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &rtd->ops);
|
|
|
|
|
|
- list_for_each_entry(component, &rtd->card->component_dev_list, card_list) {
|
|
|
- if (component->pcm_new) {
|
|
|
- ret = component->pcm_new(rtd);
|
|
|
- if (ret < 0) {
|
|
|
- dev_err(component->dev,
|
|
|
- "ASoC: pcm constructor failed: %d\n",
|
|
|
- ret);
|
|
|
- return ret;
|
|
|
- }
|
|
|
+ if (platform->driver->pcm_new) {
|
|
|
+ ret = platform->driver->pcm_new(rtd);
|
|
|
+ if (ret < 0) {
|
|
|
+ dev_err(platform->dev,
|
|
|
+ "ASoC: pcm constructor failed: %d\n",
|
|
|
+ ret);
|
|
|
+ return ret;
|
|
|
}
|
|
|
}
|
|
|
- pcm->private_free = soc_pcm_free;
|
|
|
+
|
|
|
+ pcm->private_free = platform->driver->pcm_free;
|
|
|
out:
|
|
|
dev_info(rtd->card->dev, "%s <-> %s mapping ok\n",
|
|
|
(rtd->num_codecs > 1) ? "multicodec" : rtd->codec_dai->name,
|