diff options
author | Tomi Valkeinen <tomi.valkeinen@ti.com> | 2012-09-10 12:58:29 +0200 |
---|---|---|
committer | Tomi Valkeinen <tomi.valkeinen@ti.com> | 2012-09-18 15:15:05 +0200 |
commit | 5274484b821bb2cf34a697624ef14084c31b16ce (patch) | |
tree | a5b99b98eb685414b5ff87233da5556ce80ad2f6 /drivers/video/omap2/dss/venc.c | |
parent | OMAPDSS: cleanup dss_recheck_connections further (diff) | |
download | linux-5274484b821bb2cf34a697624ef14084c31b16ce.tar.xz linux-5274484b821bb2cf34a697624ef14084c31b16ce.zip |
OMAPDSS: alloc dssdevs dynamically
We currently create omap_dss_devices statically in board files, and use
those devices directly in the omapdss driver. This model prevents us
from having the platform data (which the dssdevs in board files
practically are) as read-only, and it's also different than what we will
use with device tree.
This patch changes the model to be in line with DT model: we allocate
the dssdevs dynamically, and initialize them according to the data in
the board file's dssdev (basically we memcopy the dssdev fields).
The allocation and registration is done in the following steps in the
output drivers:
- Use dss_alloc_and_init_device to allocate and initialize the device.
The function uses kalloc and device_initialize to accomplish this.
- Call dss_copy_device_pdata to copy the data from the board file's
dssdev
- Use dss_add_device to register the device.
Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
Diffstat (limited to 'drivers/video/omap2/dss/venc.c')
-rw-r--r-- | drivers/video/omap2/dss/venc.c | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/drivers/video/omap2/dss/venc.c b/drivers/video/omap2/dss/venc.c index 88fa6ea77e74..996779c0204c 100644 --- a/drivers/video/omap2/dss/venc.c +++ b/drivers/video/omap2/dss/venc.c @@ -763,27 +763,36 @@ static struct omap_dss_device * __init venc_find_dssdev(struct platform_device * return def_dssdev; } -static void __init venc_probe_pdata(struct platform_device *pdev) +static void __init venc_probe_pdata(struct platform_device *vencdev) { + struct omap_dss_device *plat_dssdev; struct omap_dss_device *dssdev; int r; - dssdev = venc_find_dssdev(pdev); + plat_dssdev = venc_find_dssdev(vencdev); + if (!plat_dssdev) + return; + + dssdev = dss_alloc_and_init_device(&vencdev->dev); if (!dssdev) return; + dss_copy_device_pdata(dssdev, plat_dssdev); + dssdev->channel = OMAP_DSS_CHANNEL_DIGIT; r = venc_init_display(dssdev); if (r) { DSSERR("device %s init failed: %d\n", dssdev->name, r); + dss_put_device(dssdev); return; } - r = omap_dss_register_device(dssdev, &pdev->dev); + r = dss_add_device(dssdev); if (r) { DSSERR("device %s register failed: %d\n", dssdev->name, r); + dss_put_device(dssdev); return; } } @@ -848,7 +857,7 @@ err_runtime_get: static int __exit omap_venchw_remove(struct platform_device *pdev) { - omap_dss_unregister_child_devices(&pdev->dev); + dss_unregister_child_devices(&pdev->dev); if (venc.vdda_dac_reg != NULL) { regulator_put(venc.vdda_dac_reg); |