aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pwm/pwm-imx.c
diff options
context:
space:
mode:
authorSascha Hauer <s.hauer@pengutronix.de>2017-01-29 16:54:06 -0500
committerThierry Reding <thierry.reding@gmail.com>2017-01-30 03:12:18 -0500
commit9fb27fac39f47632aa32ffd787b4de1dbd0b8655 (patch)
treeb37543333010fa074c7971ddb55d1eff29c74f7d /drivers/pwm/pwm-imx.c
parentae2520540cb0090eb8cdba559bcb6a82266f0308 (diff)
pwm: imx: Remove ipg clock and enable per clock when required
The use of the ipg clock was introduced with commit 7b27c160c681 ("pwm: i.MX: fix clock lookup"). In the commit message it was claimed that the ipg clock is enabled for register accesses. This is true for the ->config() callback, but not for the ->set_enable() callback. Given that the ipg clock is not consistently enabled for all register accesses we can assume that either it is not required at all or that the current code does not work. Remove the ipg clock code for now so that it's no longer in the way of refactoring the driver. On the other hand, the i.MX 7 IP requires the peripheral clock to be enabled before accessing its registers. Since ->config() can be called when the PWM is disabled (in which case, the peripheral clock is also disabled), we need to surround the imx->config() with clk_prepare_enable(per_clk)/clk_disable_unprepare(per_clk) calls. Note that the driver was working fine for the i.MX 7 IP so far because the ipg and peripheral clock use the same hardware clock gate, which guaranteed peripheral clock activation even when ->config() was called when the PWM was disabled. Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de> Signed-off-by: Boris Brezillon <boris.brezillon@free-electrons.com> Cc: Philipp Zabel <p.zabel@pengutronix.de> Reviewed-by: Stefan Agner <stefan@agner.ch> Tested-by: Stefan Agner <stefan@agner.ch> Reviewed-by: Boris Brezillon <boris.brezillon@free-electrons.com> Signed-off-by: Thierry Reding <thierry.reding@gmail.com>
Diffstat (limited to 'drivers/pwm/pwm-imx.c')
-rw-r--r--drivers/pwm/pwm-imx.c12
1 files changed, 2 insertions, 10 deletions
diff --git a/drivers/pwm/pwm-imx.c b/drivers/pwm/pwm-imx.c
index 177fb81c916d..bb64122a74be 100644
--- a/drivers/pwm/pwm-imx.c
+++ b/drivers/pwm/pwm-imx.c
@@ -49,7 +49,6 @@
49 49
50struct imx_chip { 50struct imx_chip {
51 struct clk *clk_per; 51 struct clk *clk_per;
52 struct clk *clk_ipg;
53 52
54 void __iomem *mmio_base; 53 void __iomem *mmio_base;
55 54
@@ -206,13 +205,13 @@ static int imx_pwm_config(struct pwm_chip *chip,
206 struct imx_chip *imx = to_imx_chip(chip); 205 struct imx_chip *imx = to_imx_chip(chip);
207 int ret; 206 int ret;
208 207
209 ret = clk_prepare_enable(imx->clk_ipg); 208 ret = clk_prepare_enable(imx->clk_per);
210 if (ret) 209 if (ret)
211 return ret; 210 return ret;
212 211
213 ret = imx->config(chip, pwm, duty_ns, period_ns); 212 ret = imx->config(chip, pwm, duty_ns, period_ns);
214 213
215 clk_disable_unprepare(imx->clk_ipg); 214 clk_disable_unprepare(imx->clk_per);
216 215
217 return ret; 216 return ret;
218} 217}
@@ -293,13 +292,6 @@ static int imx_pwm_probe(struct platform_device *pdev)
293 return PTR_ERR(imx->clk_per); 292 return PTR_ERR(imx->clk_per);
294 } 293 }
295 294
296 imx->clk_ipg = devm_clk_get(&pdev->dev, "ipg");
297 if (IS_ERR(imx->clk_ipg)) {
298 dev_err(&pdev->dev, "getting ipg clock failed with %ld\n",
299 PTR_ERR(imx->clk_ipg));
300 return PTR_ERR(imx->clk_ipg);
301 }
302
303 imx->chip.ops = &imx_pwm_ops; 295 imx->chip.ops = &imx_pwm_ops;
304 imx->chip.dev = &pdev->dev; 296 imx->chip.dev = &pdev->dev;
305 imx->chip.base = -1; 297 imx->chip.base = -1;