backlight: platform_lcd: use devm_lcd_device_register()
authorJingoo Han <jg1.han@samsung.com>
Tue, 12 Nov 2013 23:09:31 +0000 (15:09 -0800)
committerLinus Torvalds <torvalds@linux-foundation.org>
Wed, 13 Nov 2013 03:09:19 +0000 (12:09 +0900)
Use devm_lcd_device_register() to make cleanup paths simpler, and remove
unnecessary remove().

Signed-off-by: Jingoo Han <jg1.han@samsung.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
drivers/video/backlight/platform_lcd.c

index cc0f0675366eb94f5ea6d3f21035e8d624e873ea..d01884d4f1bff982033e2b4e68219c37290e7cce 100644 (file)
@@ -101,29 +101,16 @@ static int platform_lcd_probe(struct platform_device *pdev)
 
        plcd->us = dev;
        plcd->pdata = pdata;
-       plcd->lcd = lcd_device_register(dev_name(dev), dev,
-                                       plcd, &platform_lcd_ops);
+       plcd->lcd = devm_lcd_device_register(&pdev->dev, dev_name(dev), dev,
+                                               plcd, &platform_lcd_ops);
        if (IS_ERR(plcd->lcd)) {
                dev_err(dev, "cannot register lcd device\n");
-               err = PTR_ERR(plcd->lcd);
-               goto err;
+               return PTR_ERR(plcd->lcd);
        }
 
        platform_set_drvdata(pdev, plcd);
        platform_lcd_set_power(plcd->lcd, FB_BLANK_NORMAL);
 
-       return 0;
-
- err:
-       return err;
-}
-
-static int platform_lcd_remove(struct platform_device *pdev)
-{
-       struct platform_lcd *plcd = platform_get_drvdata(pdev);
-
-       lcd_device_unregister(plcd->lcd);
-
        return 0;
 }
 
@@ -168,7 +155,6 @@ static struct platform_driver platform_lcd_driver = {
                .of_match_table = of_match_ptr(platform_lcd_of_match),
        },
        .probe          = platform_lcd_probe,
-       .remove         = platform_lcd_remove,
 };
 
 module_platform_driver(platform_lcd_driver);