summaryrefslogtreecommitdiffstats
path: root/drivers/gpio
diff options
context:
space:
mode:
authorAnson Huang <anson.huang@nxp.com>2019-02-22 22:18:25 -0500
committerLinus Walleij <linus.walleij@linaro.org>2019-02-25 07:42:46 -0500
commita329bbe707cee2cf8c660890ef2ad0d00ec7e8a3 (patch)
treee62ccaf8b7ce2ea9d9c7a397dceee4edca319cc8 /drivers/gpio
parentaf39459b896d732dd0ff9ef00ee59fe4ef6d1981 (diff)
gpio: mxc: add check to return defer probe if clock tree NOT ready
On i.MX8MQ platform, clock driver uses platform driver model and it is probed after GPIO driver, so when GPIO driver fails to get clock, it should check the error type to decide whether to return defer probe or just ignore the clock operation. Fixes: 2808801aab8a ("gpio: mxc: add clock operation") Signed-off-by: Anson Huang <Anson.Huang@nxp.com> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Diffstat (limited to 'drivers/gpio')
-rw-r--r--drivers/gpio/gpio-mxc.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/gpio/gpio-mxc.c b/drivers/gpio/gpio-mxc.c
index 2d1dfa1e0745..e86e61dda4b7 100644
--- a/drivers/gpio/gpio-mxc.c
+++ b/drivers/gpio/gpio-mxc.c
@@ -438,8 +438,11 @@ static int mxc_gpio_probe(struct platform_device *pdev)
438 438
439 /* the controller clock is optional */ 439 /* the controller clock is optional */
440 port->clk = devm_clk_get(&pdev->dev, NULL); 440 port->clk = devm_clk_get(&pdev->dev, NULL);
441 if (IS_ERR(port->clk)) 441 if (IS_ERR(port->clk)) {
442 if (PTR_ERR(port->clk) == -EPROBE_DEFER)
443 return -EPROBE_DEFER;
442 port->clk = NULL; 444 port->clk = NULL;
445 }
443 446
444 err = clk_prepare_enable(port->clk); 447 err = clk_prepare_enable(port->clk);
445 if (err) { 448 if (err) {