Commit bd81ed08 authored by Tomi Valkeinen's avatar Tomi Valkeinen

OMAPDSS: DSS: use omapdss_version

Use omapdss_version in dss.c to select the proper dss features.
Signed-off-by: default avatarTomi Valkeinen <tomi.valkeinen@ti.com>
parent 84b47623
...@@ -792,29 +792,46 @@ static const struct dss_features omap54xx_dss_feats __initconst = { ...@@ -792,29 +792,46 @@ static const struct dss_features omap54xx_dss_feats __initconst = {
.dpi_select_source = &dss_dpi_select_source_omap5, .dpi_select_source = &dss_dpi_select_source_omap5,
}; };
static int __init dss_init_features(struct device *dev) static int __init dss_init_features(struct platform_device *pdev)
{ {
struct omap_dss_board_info *pdata = pdev->dev.platform_data;
const struct dss_features *src; const struct dss_features *src;
struct dss_features *dst; struct dss_features *dst;
dst = devm_kzalloc(dev, sizeof(*dst), GFP_KERNEL); dst = devm_kzalloc(&pdev->dev, sizeof(*dst), GFP_KERNEL);
if (!dst) { if (!dst) {
dev_err(dev, "Failed to allocate local DSS Features\n"); dev_err(&pdev->dev, "Failed to allocate local DSS Features\n");
return -ENOMEM; return -ENOMEM;
} }
if (cpu_is_omap24xx()) switch (pdata->version) {
case OMAPDSS_VER_OMAP24xx:
src = &omap24xx_dss_feats; src = &omap24xx_dss_feats;
else if (cpu_is_omap34xx()) break;
case OMAPDSS_VER_OMAP34xx_ES1:
case OMAPDSS_VER_OMAP34xx_ES3:
case OMAPDSS_VER_AM35xx:
src = &omap34xx_dss_feats; src = &omap34xx_dss_feats;
else if (cpu_is_omap3630()) break;
case OMAPDSS_VER_OMAP3630:
src = &omap3630_dss_feats; src = &omap3630_dss_feats;
else if (cpu_is_omap44xx()) break;
case OMAPDSS_VER_OMAP4430_ES1:
case OMAPDSS_VER_OMAP4430_ES2:
case OMAPDSS_VER_OMAP4:
src = &omap44xx_dss_feats; src = &omap44xx_dss_feats;
else if (soc_is_omap54xx()) break;
case OMAPDSS_VER_OMAP5:
src = &omap54xx_dss_feats; src = &omap54xx_dss_feats;
else break;
default:
return -ENODEV; return -ENODEV;
}
memcpy(dst, src, sizeof(*dst)); memcpy(dst, src, sizeof(*dst));
dss.feat = dst; dss.feat = dst;
...@@ -831,7 +848,7 @@ static int __init omap_dsshw_probe(struct platform_device *pdev) ...@@ -831,7 +848,7 @@ static int __init omap_dsshw_probe(struct platform_device *pdev)
dss.pdev = pdev; dss.pdev = pdev;
r = dss_init_features(&dss.pdev->dev); r = dss_init_features(dss.pdev);
if (r) if (r)
return r; return r;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment