]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
backlight: corgi_lcd: convert corgi_lcd to dev_pm_ops
authorJingoo Han <jg1.han@samsung.com>
Tue, 26 Mar 2013 23:24:59 +0000 (10:24 +1100)
committerStephen Rothwell <sfr@canb.auug.org.au>
Thu, 4 Apr 2013 06:12:25 +0000 (17:12 +1100)
Instead of using legacy suspend/resume methods, using newer dev_pm_ops
structure allows better control over power management.

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

index aa782f3029835ba0b062ae2b1c5776b60577057b..c97867a717a7e0f913b01d472c4fbe460df9e9e2 100644 (file)
@@ -457,10 +457,10 @@ static const struct backlight_ops corgi_bl_ops = {
        .update_status  = corgi_bl_update_status,
 };
 
-#ifdef CONFIG_PM
-static int corgi_lcd_suspend(struct spi_device *spi, pm_message_t state)
+#ifdef CONFIG_PM_SLEEP
+static int corgi_lcd_suspend(struct device *dev)
 {
-       struct corgi_lcd *lcd = spi_get_drvdata(spi);
+       struct corgi_lcd *lcd = dev_get_drvdata(dev);
 
        corgibl_flags |= CORGIBL_SUSPENDED;
        corgi_bl_set_intensity(lcd, 0);
@@ -468,20 +468,19 @@ static int corgi_lcd_suspend(struct spi_device *spi, pm_message_t state)
        return 0;
 }
 
-static int corgi_lcd_resume(struct spi_device *spi)
+static int corgi_lcd_resume(struct device *dev)
 {
-       struct corgi_lcd *lcd = spi_get_drvdata(spi);
+       struct corgi_lcd *lcd = dev_get_drvdata(dev);
 
        corgibl_flags &= ~CORGIBL_SUSPENDED;
        corgi_lcd_set_power(lcd->lcd_dev, FB_BLANK_UNBLANK);
        backlight_update_status(lcd->bl_dev);
        return 0;
 }
-#else
-#define corgi_lcd_suspend      NULL
-#define corgi_lcd_resume       NULL
 #endif
 
+static SIMPLE_DEV_PM_OPS(corgi_lcd_pm_ops, corgi_lcd_suspend, corgi_lcd_resume);
+
 static int setup_gpio_backlight(struct corgi_lcd *lcd,
                                struct corgi_lcd_platform_data *pdata)
 {
@@ -611,11 +610,10 @@ static struct spi_driver corgi_lcd_driver = {
        .driver         = {
                .name   = "corgi-lcd",
                .owner  = THIS_MODULE,
+               .pm     = &corgi_lcd_pm_ops,
        },
        .probe          = corgi_lcd_probe,
        .remove         = corgi_lcd_remove,
-       .suspend        = corgi_lcd_suspend,
-       .resume         = corgi_lcd_resume,
 };
 
 module_spi_driver(corgi_lcd_driver);