|
@@ -182,3 +182,110 @@ static int omap_dsi_enable_pads(int dsi_id, unsigned lane_mask)
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+static void omap_dsi_disable_pads(int dsi_id, unsigned lane_mask)
|
|
|
|
+{
|
|
|
|
+ if (cpu_is_omap44xx())
|
|
|
|
+ omap4_dsi_mux_pads(dsi_id, 0);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static int omap_dss_set_min_bus_tput(struct device *dev, unsigned long tput)
|
|
|
|
+{
|
|
|
|
+ return omap_pm_set_min_bus_tput(dev, OCP_INITIATOR_AGENT, tput);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static struct platform_device *create_dss_pdev(const char *pdev_name,
|
|
|
|
+ int pdev_id, const char *oh_name, void *pdata, int pdata_len,
|
|
|
|
+ struct platform_device *parent)
|
|
|
|
+{
|
|
|
|
+ struct platform_device *pdev;
|
|
|
|
+ struct omap_device *od;
|
|
|
|
+ struct omap_hwmod *ohs[1];
|
|
|
|
+ struct omap_hwmod *oh;
|
|
|
|
+ int r;
|
|
|
|
+
|
|
|
|
+ oh = omap_hwmod_lookup(oh_name);
|
|
|
|
+ if (!oh) {
|
|
|
|
+ pr_err("Could not look up %s\n", oh_name);
|
|
|
|
+ r = -ENODEV;
|
|
|
|
+ goto err;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ pdev = platform_device_alloc(pdev_name, pdev_id);
|
|
|
|
+ if (!pdev) {
|
|
|
|
+ pr_err("Could not create pdev for %s\n", pdev_name);
|
|
|
|
+ r = -ENOMEM;
|
|
|
|
+ goto err;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (parent != NULL)
|
|
|
|
+ pdev->dev.parent = &parent->dev;
|
|
|
|
+
|
|
|
|
+ if (pdev->id != -1)
|
|
|
|
+ dev_set_name(&pdev->dev, "%s.%d", pdev->name, pdev->id);
|
|
|
|
+ else
|
|
|
|
+ dev_set_name(&pdev->dev, "%s", pdev->name);
|
|
|
|
+
|
|
|
|
+ ohs[0] = oh;
|
|
|
|
+ od = omap_device_alloc(pdev, ohs, 1, NULL, 0);
|
|
|
|
+ if (IS_ERR(od)) {
|
|
|
|
+ pr_err("Could not alloc omap_device for %s\n", pdev_name);
|
|
|
|
+ r = -ENOMEM;
|
|
|
|
+ goto err;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ r = platform_device_add_data(pdev, pdata, pdata_len);
|
|
|
|
+ if (r) {
|
|
|
|
+ pr_err("Could not set pdata for %s\n", pdev_name);
|
|
|
|
+ goto err;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ r = omap_device_register(pdev);
|
|
|
|
+ if (r) {
|
|
|
|
+ pr_err("Could not register omap_device for %s\n", pdev_name);
|
|
|
|
+ goto err;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return pdev;
|
|
|
|
+
|
|
|
|
+err:
|
|
|
|
+ return ERR_PTR(r);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static struct platform_device *create_simple_dss_pdev(const char *pdev_name,
|
|
|
|
+ int pdev_id, void *pdata, int pdata_len,
|
|
|
|
+ struct platform_device *parent)
|
|
|
|
+{
|
|
|
|
+ struct platform_device *pdev;
|
|
|
|
+ int r;
|
|
|
|
+
|
|
|
|
+ pdev = platform_device_alloc(pdev_name, pdev_id);
|
|
|
|
+ if (!pdev) {
|
|
|
|
+ pr_err("Could not create pdev for %s\n", pdev_name);
|
|
|
|
+ r = -ENOMEM;
|
|
|
|
+ goto err;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (parent != NULL)
|
|
|
|
+ pdev->dev.parent = &parent->dev;
|
|
|
|
+
|
|
|
|
+ if (pdev->id != -1)
|
|
|
|
+ dev_set_name(&pdev->dev, "%s.%d", pdev->name, pdev->id);
|
|
|
|
+ else
|
|
|
|
+ dev_set_name(&pdev->dev, "%s", pdev->name);
|
|
|
|
+
|
|
|
|
+ r = platform_device_add_data(pdev, pdata, pdata_len);
|
|
|
|
+ if (r) {
|
|
|
|
+ pr_err("Could not set pdata for %s\n", pdev_name);
|
|
|
|
+ goto err;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ r = platform_device_add(pdev);
|
|
|
|
+ if (r) {
|
|
|
|
+ pr_err("Could not register platform_device for %s\n", pdev_name);
|
|
|
|
+ goto err;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return pdev;
|
|
|
|
+
|
|
|
|
+err:
|
|
|
|
+ return ERR_PTR(r);
|