gpu: ipu-v3: hook up PRG unit
authorLucas Stach <l.stach@pengutronix.de>
Wed, 8 Mar 2017 11:13:18 +0000 (12:13 +0100)
committerPhilipp Zabel <p.zabel@pengutronix.de>
Thu, 16 Mar 2017 09:14:39 +0000 (10:14 +0100)
The i.MX6 QuadPlus IPU needs to PRG unit to gain access to the
data bus. Make sure it is present and available to be used.

Signed-off-by: Lucas Stach <l.stach@pengutronix.de>
Signed-off-by: Philipp Zabel <p.zabel@pengutronix.de>
drivers/gpu/ipu-v3/ipu-common.c

index 4c845398974673cd18508eeb99d9bbe297db56c6..7aefccec31b1e84ef8ab5a0b7ed98b0fca37ce11 100644 (file)
@@ -939,6 +939,7 @@ static const struct of_device_id imx_ipu_dt_ids[] = {
        { .compatible = "fsl,imx51-ipu", .data = &ipu_type_imx51, },
        { .compatible = "fsl,imx53-ipu", .data = &ipu_type_imx53, },
        { .compatible = "fsl,imx6q-ipu", .data = &ipu_type_imx6q, },
+       { .compatible = "fsl,imx6qp-ipu", .data = &ipu_type_imx6q, },
        { /* sentinel */ }
 };
 MODULE_DEVICE_TABLE(of, imx_ipu_dt_ids);
@@ -1398,11 +1399,19 @@ static int ipu_probe(struct platform_device *pdev)
        if (!ipu)
                return -ENODEV;
 
+       ipu->id = of_alias_get_id(np, "ipu");
+
+       if (of_device_is_compatible(np, "fsl,imx6qp-ipu")) {
+               ipu->prg_priv = ipu_prg_lookup_by_phandle(&pdev->dev,
+                                                         "fsl,prg", ipu->id);
+               if (!ipu->prg_priv)
+                       return -EPROBE_DEFER;
+       }
+
        for (i = 0; i < 64; i++)
                ipu->channel[i].ipu = ipu;
        ipu->devtype = devtype;
        ipu->ipu_type = devtype->type;
-       ipu->id = of_alias_get_id(np, "ipu");
 
        spin_lock_init(&ipu->lock);
        mutex_init(&ipu->channel_lock);