summaryrefslogtreecommitdiffstats
path: root/sound/soc/rockchip/rockchip_max98090.c
diff options
context:
space:
mode:
authorCheng-Yi Chiang <cychiang@chromium.org>2019-08-13 09:44:30 +0200
committerMark Brown <broonie@kernel.org>2019-08-13 13:39:31 +0200
commit7188f656cdf762d4ea8ce16b6aaf4c6b06e119ec (patch)
tree98f006b4c1cd5a900535af3fbd4afb1d741099a4 /sound/soc/rockchip/rockchip_max98090.c
parentASoC: Intel: sof-rt5682: add dmic dapm widget to support dmic PCM (diff)
downloadlinux-7188f656cdf762d4ea8ce16b6aaf4c6b06e119ec.tar.xz
linux-7188f656cdf762d4ea8ce16b6aaf4c6b06e119ec.zip
ASoC: rockchip: rockchip_max98090: Set period size to 240
From stress testing of arecord, we found that period size greater than ~900 will bring pl330 to DYING state and can not recover within 100 iterations. The result is that arecord will stuck and get I/O error, and issue can not be recovered until reboot. This issue does not happen when period size is small. Set constraint of period size to 240 to prevent such issue. With the constraint, there will be no issue after 2000 iterations. We can revert this patch once the root cause is found in rockchip's pl330 implementation. Signed-off-by: Cheng-Yi Chiang <cychiang@chromium.org> Link: https://lore.kernel.org/r/20190813074430.191791-1-cychiang@chromium.org Signed-off-by: Mark Brown <broonie@kernel.org>
Diffstat (limited to 'sound/soc/rockchip/rockchip_max98090.c')
-rw-r--r--sound/soc/rockchip/rockchip_max98090.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/sound/soc/rockchip/rockchip_max98090.c b/sound/soc/rockchip/rockchip_max98090.c
index 782e534d4c0d..d54f672d38d8 100644
--- a/sound/soc/rockchip/rockchip_max98090.c
+++ b/sound/soc/rockchip/rockchip_max98090.c
@@ -138,8 +138,19 @@ static int rk_aif1_hw_params(struct snd_pcm_substream *substream,
return ret;
}
+static int rk_aif1_startup(struct snd_pcm_substream *substream)
+{
+ /*
+ * Set period size to 240 because pl330 has issue
+ * dealing with larger period in stress testing.
+ */
+ return snd_pcm_hw_constraint_minmax(substream->runtime,
+ SNDRV_PCM_HW_PARAM_PERIOD_SIZE, 240, 240);
+}
+
static const struct snd_soc_ops rk_aif1_ops = {
.hw_params = rk_aif1_hw_params,
+ .startup = rk_aif1_startup,
};
SND_SOC_DAILINK_DEFS(hifi,