mtd: hyperbus: hbmc-am654: Fix direct mapping setup flash access
authorVignesh Raghavendra <vigneshr@ti.com>
Thu, 24 Sep 2020 08:12:12 +0000 (13:42 +0530)
committerVignesh Raghavendra <vigneshr@ti.com>
Wed, 30 Sep 2020 08:05:18 +0000 (13:35 +0530)
Setting up of direct mapping should be done with flash node's IO
address space and not with controller's IO region.

Fixes: b6fe8bc67d2d3 ("mtd: hyperbus: move direct mapping setup to AM654 HBMC driver")
Signed-off-by: Vignesh Raghavendra <vigneshr@ti.com>
Link: https://lore.kernel.org/r/20200924081214.16934-3-vigneshr@ti.com
drivers/mtd/hyperbus/hbmc-am654.c

index e0e33f6bf513bebb80e753ced282055177c114b0..1e70ecfffa39f9a92764c2da7b3084e7c9ef067c 100644 (file)
@@ -70,7 +70,8 @@ static int am654_hbmc_probe(struct platform_device *pdev)
 
        platform_set_drvdata(pdev, priv);
 
-       ret = of_address_to_resource(np, 0, &res);
+       priv->hbdev.np = of_get_next_child(np, NULL);
+       ret = of_address_to_resource(priv->hbdev.np, 0, &res);
        if (ret)
                return ret;
 
@@ -103,7 +104,6 @@ static int am654_hbmc_probe(struct platform_device *pdev)
        priv->ctlr.dev = dev;
        priv->ctlr.ops = &am654_hbmc_ops;
        priv->hbdev.ctlr = &priv->ctlr;
-       priv->hbdev.np = of_get_next_child(dev->of_node, NULL);
        ret = hyperbus_register_device(&priv->hbdev);
        if (ret) {
                dev_err(dev, "failed to register controller\n");