OMAPDSS: handle errors in dss_init_device
authorTomi Valkeinen <tomi.valkeinen@ti.com>
Fri, 7 Sep 2012 12:44:30 +0000 (15:44 +0300)
committerTomi Valkeinen <tomi.valkeinen@ti.com>
Tue, 18 Sep 2012 13:15:03 +0000 (16:15 +0300)
Add error handling to dss_init_device(), which has, for some reason,
been missing.

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

index 315f557f1d1a3ea07f13b28399acf5aede13664c..9315ece90ff178dcc9782a96b3c45f1e1a6e9d6f 100644 (file)
@@ -358,7 +358,9 @@ static int dss_driver_probe(struct device *dev)
                                dev_name(dev), dssdev->driver_name,
                                dssdrv->driver.name);
 
-       dss_init_device(core.pdev, dssdev);
+       r = dss_init_device(core.pdev, dssdev);
+       if (r)
+               return r;
 
        force = core.default_display_name &&
                strcmp(core.default_display_name, dssdev->name) == 0;
index 5f09d503d61965c111f814c4b624fcee76ee2eb9..f7190109bd915f28ce6a5d9057c97d528c615e9c 100644 (file)
@@ -320,26 +320,39 @@ void omapdss_default_get_timings(struct omap_dss_device *dssdev,
 }
 EXPORT_SYMBOL(omapdss_default_get_timings);
 
-void dss_init_device(struct platform_device *pdev,
+int dss_init_device(struct platform_device *pdev,
                struct omap_dss_device *dssdev)
 {
        struct device_attribute *attr;
-       int i;
-       int r;
+       int i, r;
 
        /* create device sysfs files */
        i = 0;
        while ((attr = display_sysfs_attrs[i++]) != NULL) {
                r = device_create_file(&dssdev->dev, attr);
-               if (r)
+               if (r) {
+                       for (i = i - 2; i >= 0; i--) {
+                               attr = display_sysfs_attrs[i];
+                               device_remove_file(&dssdev->dev, attr);
+                       }
+
                        DSSERR("failed to create sysfs file\n");
+                       return r;
+               }
        }
 
        /* create display? sysfs links */
        r = sysfs_create_link(&pdev->dev.kobj, &dssdev->dev.kobj,
                        dev_name(&dssdev->dev));
-       if (r)
+       if (r) {
+               while ((attr = display_sysfs_attrs[i++]) != NULL)
+                       device_remove_file(&dssdev->dev, attr);
+
                DSSERR("failed to create sysfs display link\n");
+               return r;
+       }
+
+       return 0;
 }
 
 void dss_uninit_device(struct platform_device *pdev,
index a977826d850cab07aef21a8d3ca108aa0e2275a6..98e82731c60add50a831924a79453d29144023f8 100644 (file)
@@ -228,7 +228,7 @@ int dss_suspend_all_devices(void);
 int dss_resume_all_devices(void);
 void dss_disable_all_devices(void);
 
-void dss_init_device(struct platform_device *pdev,
+int dss_init_device(struct platform_device *pdev,
                struct omap_dss_device *dssdev);
 void dss_uninit_device(struct platform_device *pdev,
                struct omap_dss_device *dssdev);