From 35c7c2d6b01a09ad23a1f1b3cb66aa7c936cb69c Mon Sep 17 00:00:00 2001 From: "Yin, Fengwei" Date: Thu, 14 May 2015 23:09:42 +0800 Subject: Enable xo clock before operate wcnss registers. Signed-off-by: Yin, Fengwei --- drivers/net/wireless/ath/wcn36xx/wcnss_core.c | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/drivers/net/wireless/ath/wcn36xx/wcnss_core.c b/drivers/net/wireless/ath/wcn36xx/wcnss_core.c index 66e31440f3c3..707e6288f4fe 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; } -- cgit v1.2.3