OMAPDSS: DPI: Store dpi_data pointer in the DT port's data
authorArchit Taneja <archit@ti.com>
Mon, 2 Jun 2014 08:41:51 +0000 (14:11 +0530)
committerTomi Valkeinen <tomi.valkeinen@ti.com>
Wed, 12 Nov 2014 11:39:57 +0000 (13:39 +0200)
DPI and SDI ports are backed by only one parent DSS device. We don't have a
corresponding platform_device for ports under DSS. In order to support multiple
instances of DPI, we need to pass the driver data pointer through the DPI port's
private data ('data' member in device_node struct).

dpi_init_output/dpi_uninit_output are untouched and only used for non-DT case,
these are called when the DPI platform device probed/removed. These funcs will
be removed when non-DT mode is removed.

dpi_init_output_port/dpi_uninit_output_port are created and used for the DT
path, called when DSS inits/uninits it's ports. These new functions retrieve
the dpi_data pointer from 'port->data', and not from the platform device's
data(pdev->dev) like in the non-DT path.

We add some code in dss_uninit_ports() to pass a pointer to the DPI port in
dpi_uninit_port().

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

index c9face608b2afa7038e1f39676b983ab2b943b1a..224d7885eeeb32c446e0420083c4d14761bb35b1 100644 (file)
@@ -59,6 +59,7 @@ static struct dpi_data *dpi_get_data_from_dssdev(struct omap_dss_device *dssdev)
        return container_of(dssdev, struct dpi_data, output);
 }
 
+/* only used in non-DT mode */
 static struct dpi_data *dpi_get_data_from_pdev(struct platform_device *pdev)
 {
        return dev_get_drvdata(&pdev->dev);
@@ -724,6 +725,30 @@ static void __exit dpi_uninit_output(struct platform_device *pdev)
        omapdss_unregister_output(out);
 }
 
+static void dpi_init_output_port(struct platform_device *pdev,
+       struct device_node *port)
+{
+       struct dpi_data *dpi = port->data;
+       struct omap_dss_device *out = &dpi->output;
+
+       out->dev = &pdev->dev;
+       out->id = OMAP_DSS_OUTPUT_DPI;
+       out->output_type = OMAP_DISPLAY_TYPE_DPI;
+       out->dispc_channel = dpi_get_channel();
+       out->ops.dpi = &dpi_ops;
+       out->owner = THIS_MODULE;
+
+       omapdss_register_output(out);
+}
+
+static void __exit dpi_uninit_output_port(struct device_node *port)
+{
+       struct dpi_data *dpi = port->data;
+       struct omap_dss_device *out = &dpi->output;
+
+       omapdss_unregister_output(out);
+}
+
 static int omap_dpi_probe(struct platform_device *pdev)
 {
        struct dpi_data *dpi;
@@ -796,15 +821,14 @@ int __init dpi_init_port(struct platform_device *pdev, struct device_node *port)
        of_node_put(ep);
 
        dpi->pdev = pdev;
+       port->data = dpi;
 
        mutex_init(&dpi->lock);
 
-       dpi_init_output(pdev);
+       dpi_init_output_port(pdev, port);
 
        dpi->port_initialized = true;
 
-       dev_set_drvdata(&pdev->dev, dpi);
-
        return 0;
 
 err_datalines:
@@ -813,12 +837,12 @@ err_datalines:
        return r;
 }
 
-void __exit dpi_uninit_port(struct platform_device *pdev)
+void __exit dpi_uninit_port(struct device_node *port)
 {
-       struct dpi_data *dpi = dpi_get_data_from_pdev(pdev);
+       struct dpi_data *dpi = port->data;
 
        if (!dpi->port_initialized)
                return;
 
-       dpi_uninit_output(dpi->pdev);
+       dpi_uninit_output_port(port);
 }
index 8a4a6d2d1edfa94c7cd3b337160baaab990a4334..391a6da55e8df4207d14e6b62e0f1a7e32b2077f 100644 (file)
@@ -822,8 +822,18 @@ static int __init dss_init_ports(struct platform_device *pdev)
 
 static void __exit dss_uninit_ports(struct platform_device *pdev)
 {
+       struct device_node *parent = pdev->dev.of_node;
+       struct device_node *port;
+
+       if (parent == NULL)
+               return;
+
+       port = omapdss_of_get_next_port(parent, NULL);
+       if (!port)
+               return;
+
 #ifdef CONFIG_OMAP2_DSS_DPI
-       dpi_uninit_port(pdev);
+       dpi_uninit_port(port);
 #endif
 
 #ifdef CONFIG_OMAP2_DSS_SDI
index da7f5f9bc270673d7b17a505da75d0168f5e5c83..5b9db95533bd6354c922b4369afea86d441dfef1 100644 (file)
@@ -359,7 +359,7 @@ int dpi_init_platform_driver(void) __init;
 void dpi_uninit_platform_driver(void) __exit;
 
 int dpi_init_port(struct platform_device *pdev, struct device_node *port) __init;
-void dpi_uninit_port(struct platform_device *pdev) __exit;
+void dpi_uninit_port(struct device_node *port) __exit;
 
 /* DISPC */
 int dispc_init_platform_driver(void) __init;