OMAPDSS: DPI: fix regulators for DT
authorTomi Valkeinen <tomi.valkeinen@ti.com>
Tue, 19 Mar 2013 09:33:52 +0000 (11:33 +0200)
committerTomi Valkeinen <tomi.valkeinen@ti.com>
Mon, 17 Jun 2013 11:00:45 +0000 (14:00 +0300)
On some platforms DPI requires a regulator to be enabled to power up the
output pins. This regulator is, for some reason, currently attached to
the virtual omapdss device, instead of the DPI device. This does not
work for DT, as the regulator mappings need to be described in the DT
data, and the virtual omapdss device is not present there.

Fix the issue by acquiring the regulator in the DPI device. To retain
compatibility with the current board files, the old method of getting
the regulator is kept. The old method can be removed when the board
files have been changed to pass the regulator to DPI.

Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
drivers/video/omap2/dss/dpi.c

index 0aa396b36e7e4a529026fee9f40276cdb4d2bfb2..aa653c46d9a492f26ce6681059f5bb3096e9e1fa 100644 (file)
@@ -37,6 +37,8 @@
 #include "dss_features.h"
 
 static struct {
+       struct platform_device *pdev;
+
        struct regulator *vdds_dsi_reg;
        struct platform_device *dsidev;
 
@@ -555,8 +557,11 @@ static int dpi_init_regulator(void)
        vdds_dsi = dss_get_vdds_dsi();
 
        if (IS_ERR(vdds_dsi)) {
-               DSSERR("can't get VDDS_DSI regulator\n");
-               return PTR_ERR(vdds_dsi);
+               vdds_dsi = devm_regulator_get(&dpi.pdev->dev, "vdds_dsi");
+               if (IS_ERR(vdds_dsi)) {
+                       DSSERR("can't get VDDS_DSI regulator\n");
+                       return PTR_ERR(vdds_dsi);
+               }
        }
 
        dpi.vdds_dsi_reg = vdds_dsi;
@@ -707,6 +712,8 @@ static int omap_dpi_probe(struct platform_device *pdev)
 {
        int r;
 
+       dpi.pdev = pdev;
+
        mutex_init(&dpi.lock);
 
        dpi_init_output(pdev);