aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYin, Fengwei <fengwei.yin@linaro.org>2015-05-14 23:09:42 +0800
committerYin, Fengwei <fengwei.yin@linaro.org>2015-06-11 11:17:39 +0800
commit4623cff72dadcb0885b58a7e005509a43eef58e4 (patch)
tree6644fd8d6b88658ccd19e08cb8b1ea8c140eef7c
parent726559ba4591e702536af67cf9fd1cf1e225ed21 (diff)
Enable xo clock before operate wcnss registers.
Signed-off-by: Yin, Fengwei <fengwei.yin@linaro.org>
-rw-r--r--drivers/net/wireless/ath/wcn36xx/wcnss_core.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/drivers/net/wireless/ath/wcn36xx/wcnss_core.c b/drivers/net/wireless/ath/wcn36xx/wcnss_core.c
index 66e31440f3c34..707e6288f4fe0 100644
--- a/drivers/net/wireless/ath/wcn36xx/wcnss_core.c
+++ b/drivers/net/wireless/ath/wcn36xx/wcnss_core.c
@@ -15,8 +15,22 @@
static int wcnss_core_config(struct platform_device *pdev, void __iomem *base)
{
int ret = 0;
+ struct clk *clk = NULL;
u32 value;
+ clk = clk_get(&pdev->dev, "xo");
+ if (IS_ERR(clk)) {
+ dev_err(&pdev->dev, "can't get clock xo\n");
+ return PTR_ERR(clk);
+ }
+
+ ret = clk_prepare_enable(clk);
+ if (ret) {
+ dev_err(&pdev->dev, "clock xo enabling failed\n");
+ clk_put(clk);
+ return ret;
+ }
+
value = readl_relaxed(base + SPARE_OFFSET);
value |= WCNSS_FW_DOWNLOAD_ENABLE;
writel_relaxed(value, base + SPARE_OFFSET);
@@ -57,9 +71,12 @@ static int wcnss_core_config(struct platform_device *pdev, void __iomem *base)
value &= ~(WCNSS_PMU_CFG_GC_BUS_MUX_SEL_TOP |
WCNSS_PMU_CFG_IRIS_XO_CFG);
writel_relaxed(value, base + PMU_OFFSET);
+ clk_disable_unprepare(clk);
msleep(200);
+ clk_put(clk);
+
return ret;
}