From: Jiaxin Yu <jiaxin.yu@mediatek•com>
To: <broonie@kernel•org>, <mark.rutland@arm•com>,
<robh+dt@kernel•org>, <linux@roeck-us•net>,
<wim@linux-watchdog•org>
Cc: alsa-devel@alsa-project•org, yong.liang@mediatek•com,
lgirdwood@gmail•com, jiaxin.yu@mediatek•com, perex@perex•cz,
tzungbi@google•com, linux-mediatek@lists•infradead.org,
eason.yen@mediatek•com, linux-arm-kernel@lists•infradead.org
Subject: [PATCH 4/4] WIP: ASoC: mt8183: fix audio playback slowly after playback during bootup
Date: Fri, 27 Sep 2019 17:26:57 +0800 [thread overview]
Message-ID: <1569576417-20663-5-git-send-email-jiaxin.yu@mediatek.com> (raw)
In-Reply-To: <1569576417-20663-1-git-send-email-jiaxin.yu@mediatek.com>
Before regmap_reinit_cache we must reset audio regs as default values.
So we use reset controller unit(toprgu) to reset audio hw.
Signed-off-by: Jiaxin Yu <jiaxin.yu@mediatek•com>
---
sound/soc/mediatek/mt8183/mt8183-afe-pcm.c | 15 +++++++++++++++
1 file changed, 15 insertions(+)
diff --git a/sound/soc/mediatek/mt8183/mt8183-afe-pcm.c b/sound/soc/mediatek/mt8183/mt8183-afe-pcm.c
index 4a31106d3471..721632386a50 100644
--- a/sound/soc/mediatek/mt8183/mt8183-afe-pcm.c
+++ b/sound/soc/mediatek/mt8183/mt8183-afe-pcm.c
@@ -11,6 +11,7 @@
#include <linux/of.h>
#include <linux/of_address.h>
#include <linux/pm_runtime.h>
+#include <linux/reset.h>
#include "mt8183-afe-common.h"
#include "mt8183-afe-clk.h"
@@ -1089,6 +1090,7 @@ static int mt8183_afe_pcm_dev_probe(struct platform_device *pdev)
struct mtk_base_afe *afe;
struct mt8183_afe_private *afe_priv;
struct device *dev;
+ struct reset_control *rstc;
int i, irq_id, ret;
afe = devm_kzalloc(&pdev->dev, sizeof(*afe), GFP_KERNEL);
@@ -1126,6 +1128,19 @@ static int mt8183_afe_pcm_dev_probe(struct platform_device *pdev)
return ret;
}
+ rstc = devm_reset_control_get(dev, "audiosys");
+ if (IS_ERR(rstc)) {
+ ret = PTR_ERR(rstc);
+ dev_err(dev, "could not get audiosys reset:%d\n", ret);
+ return ret;
+ }
+
+ ret = reset_control_reset(rstc);
+ if (ret) {
+ dev_err(dev, "failed to trigger audio reset:%d\n", ret);
+ return ret;
+ }
+
/* enable clock for regcache get default value from hw */
afe_priv->pm_runtime_bypass_reg_ctl = true;
pm_runtime_get_sync(&pdev->dev);
--
2.18.0
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists•infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
prev parent reply other threads:[~2019-09-27 9:27 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-09-27 9:26 [PATCH 0/4] ASoC: mt8183: fix audio playback slowly after playback Jiaxin Yu
2019-09-27 9:26 ` [PATCH 1/4] WIP: dt-bindings: mediatek: mt8183: Add #reset-cells Jiaxin Yu
2019-09-27 9:26 ` [PATCH 2/4] WIP: watchdog: mtk_wdt: mt8183: Add reset controller Jiaxin Yu
2019-09-27 9:26 ` [PATCH 3/4] WIP: dt-bindings: medaitek: mt8183: add property "resets" && "reset-names" Jiaxin Yu
2019-09-27 9:26 ` Jiaxin Yu [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1569576417-20663-5-git-send-email-jiaxin.yu@mediatek.com \
--to=jiaxin.yu@mediatek$(echo .)com \
--cc=alsa-devel@alsa-project$(echo .)org \
--cc=broonie@kernel$(echo .)org \
--cc=eason.yen@mediatek$(echo .)com \
--cc=lgirdwood@gmail$(echo .)com \
--cc=linux-arm-kernel@lists$(echo .)infradead.org \
--cc=linux-mediatek@lists$(echo .)infradead.org \
--cc=linux@roeck-us$(echo .)net \
--cc=mark.rutland@arm$(echo .)com \
--cc=perex@perex$(echo .)cz \
--cc=robh+dt@kernel$(echo .)org \
--cc=tzungbi@google$(echo .)com \
--cc=wim@linux-watchdog$(echo .)org \
--cc=yong.liang@mediatek$(echo .)com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox