1. 28 Sep, 2020 6 commits
    • Kuninori Morimoto's avatar
      ASoC: soc-pcm: add soc_pcm_clean() and call it from soc_pcm_open/close() · 140a4532
      Kuninori Morimoto authored
      soc_pcm_open() does rollback when failed (A),
      but, it is almost same as soc_pcm_close().
      
      	static int soc_pcm_open(xxx)
      	{
      		...
      		if (ret < 0)
      			goto xxx_err;
      		...
      		return 0;
      
       ^	config_err:
       |		...
       |	rtd_startup_err:
      (A)		...
       |	component_err:
       |		...
       v		return ret;
      	}
      
      The difference is
      soc_pcm_close() is for all dai/component/substream,
      rollback        is for succeeded part only.
      
      This kind of duplicated code can be a hotbed of bugs,
      thus, we want to share soc_pcm_close() and rollback.
      
      Now, soc_pcm_open/close() are handling
      	1) snd_soc_dai_startup/shutdown()
      	2) snd_soc_link_startup/shutdown()
      	3) snd_soc_component_module_get/put()
      	4) snd_soc_component_open/close()
      	5) pm_runtime_put/get()
      
      Now, 1) to 5) are handled.
      This patch adds new soc_pcm_clean() and call it from
      soc_pcm_open() as rollback, and from soc_pcm_close() as
      normal close handler.
      
      One note here is that it don't need to call snd_soc_runtime_deactivate()
      when rollback case, because it will be called without
      snd_soc_runtime_activate().
      It also don't need to call snd_soc_dapm_stream_stop() when rollback case.
      Signed-off-by: default avatarKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
      Link: https://lore.kernel.org/r/87ft72bwn4.wl-kuninori.morimoto.gx@renesas.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      140a4532
    • Kuninori Morimoto's avatar
      ASoC: soc-component: add mark for snd_soc_pcm_component_pm_runtime_get/put() · 939a5cfb
      Kuninori Morimoto authored
      soc_pcm_open() does rollback when failed (A),
      but, it is almost same as soc_pcm_close().
      
      	static int soc_pcm_open(xxx)
      	{
      		...
      		if (ret < 0)
      			goto xxx_err;
      		...
      		return 0;
      
       ^	config_err:
       |		...
       |	rtd_startup_err:
      (A)		...
       |	component_err:
       |		...
       v		return ret;
      	}
      
      The difference is
      soc_pcm_close() is for all dai/component/substream,
      rollback        is for succeeded part only.
      
      This kind of duplicated code can be a hotbed of bugs,
      thus, we want to share soc_pcm_close() and rollback.
      
      Now, soc_pcm_open/close() are handling
      	1) snd_soc_dai_startup/shutdown()
      	2) snd_soc_link_startup/shutdown()
      	3) snd_soc_component_module_get/put()
      	4) snd_soc_component_open/close()
      =>	5) pm_runtime_put/get()
      
      This patch is for 5) pm_runtime_put/get().
      
      The idea of having bit-flag or counter is not enough for this purpose.
      For example if one DAI is used for 2xPlaybacks for some reasons,
      and if 1st Playback was succeeded but 2nd Playback was failed,
      2nd Playback rollback doesn't need to call shutdown.
      But it has succeeded bit-flag or counter via 1st Playback,
      thus, 2nd Playback rollback will call unneeded shutdown.
      And 1st Playback's necessary shutdown will not be called,
      because bit-flag or counter was cleared by wrong 2nd Playback rollback.
      
      To avoid such case, this patch marks substream pointer when get() was
      succeeded. If rollback needed, it will check rollback flag and marked
      substream pointer.
      
      One note here is that it cares *current* get() only now.
      but we might want to check *whole* marked substream in the future.
      This patch is using macro named "push/pop", so that it can be easily
      update.
      Signed-off-by: default avatarKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
      Link: https://lore.kernel.org/r/87h7ribwnb.wl-kuninori.morimoto.gx@renesas.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      939a5cfb
    • Kuninori Morimoto's avatar
      ASoC: soc-component: add mark for soc_pcm_components_open/close() · 51aff91a
      Kuninori Morimoto authored
      soc_pcm_open() does rollback when failed (A),
      but, it is almost same as soc_pcm_close().
      
      	static int soc_pcm_open(xxx)
      	{
      		...
      		if (ret < 0)
      			goto xxx_err;
      		...
      		return 0;
      
       ^	config_err:
       |		...
       |	rtd_startup_err:
      (A)		...
       |	component_err:
       |		...
       v		return ret;
      	}
      
      The difference is
      soc_pcm_close() is for all dai/component/substream,
      rollback        is for succeeded part only.
      
      This kind of duplicated code can be a hotbed of bugs,
      thus, we want to share soc_pcm_close() and rollback.
      
      Now, soc_pcm_open/close() are handling
      	1) snd_soc_dai_startup/shutdown()
      	2) snd_soc_link_startup/shutdown()
      =>	3) snd_soc_component_module_get/put()
      =>	4) snd_soc_component_open/close()
      	5) pm_runtime_put/get()
      
      This patch is for 3) snd_soc_component_module_get/put()
      4) snd_soc_component_open/close().
      
      The idea of having bit-flag or counter is not enough for this purpose.
      For example if one DAI is used for 2xPlaybacks for some reasons,
      and if 1st Playback was succeeded but 2nd Playback was failed,
      2nd Playback rollback doesn't need to call shutdown.
      But it has succeeded bit-flag or counter via 1st Playback,
      thus, 2nd Playback rollback will call unneeded shutdown.
      And 1st Playback's necessary shutdown will not be called,
      because bit-flag or counter was cleared by wrong 2nd Playback rollback.
      
      To avoid such case, this patch marks substream pointer when open() was
      succeeded. If rollback needed, it will check rollback flag and marked
      substream pointer.
      
      One note here is that it cares *current* open() only now.
      but we might want to check *whole* marked substream in the future.
      This patch is using macro named "push/pop", so that it can be easily
      update.
      Signed-off-by: default avatarKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
      Link: https://lore.kernel.org/r/87imbybwno.wl-kuninori.morimoto.gx@renesas.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      51aff91a
    • Kuninori Morimoto's avatar
      ASoC: soc-link: add mark for snd_soc_link_startup/shutdown() · 6064ed73
      Kuninori Morimoto authored
      soc_pcm_open() does rollback when failed (A),
      but, it is almost same as soc_pcm_close().
      
      	static int soc_pcm_open(xxx)
      	{
      		...
      		if (ret < 0)
      			goto xxx_err;
      		...
      		return 0;
      
       ^	config_err:
       |		...
       |	rtd_startup_err:
      (A)		...
       |	component_err:
       |		...
       v		return ret;
      	}
      
      The difference is
      soc_pcm_close() is for all dai/component/substream,
      rollback        is for succeeded part only.
      
      This kind of duplicated code can be a hotbed of bugs,
      thus, we want to share soc_pcm_close() and rollback.
      
      Now, soc_pcm_open/close() are handling
      	1) snd_soc_dai_startup/shutdown()
      =>	2) snd_soc_link_startup/shutdown()
      	3) snd_soc_component_module_get/put()
      	4) snd_soc_component_open/close()
      	5) pm_runtime_put/get()
      
      This patch is for 2) snd_soc_link_startup/shutdown().
      
      The idea of having bit-flag or counter is not enough for this purpose.
      For example if one DAI is used for 2xPlaybacks for some reasons,
      and if 1st Playback was succeeded but 2nd Playback was failed,
      2nd Playback rollback doesn't need to call shutdown.
      But it has succeeded bit-flag or counter via 1st Playback,
      thus, 2nd Playback rollback will call unneeded shutdown.
      And 1st Playback's necessary shutdown will not be called,
      because bit-flag or counter was cleared by wrong 2nd Playback rollback.
      
      To avoid such case, this patch marks substream pointer when startup() was
      succeeded. If rollback needed, it will check rollback flag and marked
      substream pointer.
      
      One note here is that it cares *current* startup() only now.
      but we might want to check *whole* marked substream in the future.
      This patch is using macro named "push/pop", so that it can be easily
      update.
      Signed-off-by: default avatarKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
      Link: https://lore.kernel.org/r/87k0webwnv.wl-kuninori.morimoto.gx@renesas.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      6064ed73
    • Kuninori Morimoto's avatar
      ASoC: soc-dai: add mark for snd_soc_dai_startup/shutdown() · 00a0b46c
      Kuninori Morimoto authored
      soc_pcm_open() does rollback when failed (A),
      but, it is almost same as soc_pcm_close().
      
      	static int soc_pcm_open(xxx)
      	{
      		...
      		if (ret < 0)
      			goto xxx_err;
      		...
      		return 0;
      
       ^	config_err:
       |		...
       |	rtd_startup_err:
      (A)		...
       |	component_err:
       |		...
       v		return ret;
      	}
      
      The difference is
      soc_pcm_close() is for all dai/component/substream,
      rollback        is for succeeded part only.
      
      This kind of duplicated code can be a hotbed of bugs,
      thus, we want to share soc_pcm_close() and rollback.
      
      Now, soc_pcm_open/close() are handling
      =>	1) snd_soc_dai_startup/shutdown()
      	2) snd_soc_link_startup/shutdown()
      	3) snd_soc_component_module_get/put()
      	4) snd_soc_component_open/close()
      	5) pm_runtime_put/get()
      
      This patch is for 1) snd_soc_dai_startup/shutdown().
      
      The idea of having bit-flag or counter is not enough for this purpose.
      For example if one DAI is used for 2xPlaybacks for some reasons,
      and if 1st Playback was succeeded but 2nd Playback was failed,
      2nd Playback rollback doesn't need to call shutdown.
      But it has succeeded bit-flag or counter via 1st Playback,
      thus, 2nd Playback rollback will call unneeded shutdown.
      And 1st Playback's necessary shutdown will not be called,
      because bit-flag or counter was cleared by wrong 2nd Playback rollback.
      
      To avoid such case, this patch marks substream pointer when startup() was
      succeeded. If rollback needed, it will check rollback flag and marked
      substream pointer.
      
      One note here is that it cares *current* startup() only now.
      but we might want to check *whole* marked substream in the future.
      This patch is using macro named "push/pop", so that it can be easily
      update.
      Signed-off-by: default avatarKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
      Link: https://lore.kernel.org/r/87lfgubwoc.wl-kuninori.morimoto.gx@renesas.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      00a0b46c
    • Srinivas Kandagatla's avatar
      ASoC: q6afe-clocks: Fix typo in SPDX Licence · d56a7ed2
      Srinivas Kandagatla authored
      Looks like there was a major typo in SPDX Licence version,
      Not sure how it was missed.
      This patch is to fix it.
      Reported-by: default avatarLukas Bulwahn <lukas.bulwahn@gmail.com>
      Signed-off-by: default avatarSrinivas Kandagatla <srinivas.kandagatla@linaro.org>
      Link: https://lore.kernel.org/r/20200926171844.7792-1-srinivas.kandagatla@linaro.orgSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      d56a7ed2
  2. 25 Sep, 2020 9 commits
  3. 23 Sep, 2020 13 commits
  4. 22 Sep, 2020 3 commits
  5. 21 Sep, 2020 9 commits