extcon: gpio: Add power resume support
authorRongjun Ying <rongjun.ying@csr.com>
Thu, 9 Jan 2014 00:50:13 +0000 (09:50 +0900)
committerChanwoo Choi <cw00.choi@samsung.com>
Thu, 9 Jan 2014 00:53:30 +0000 (09:53 +0900)
When system on the suspend state, Some SoC can't get gpio interrupt.
After system resume, need send extcon uevent to userspace.

Signed-off-by: Rongjun Ying <rongjun.ying@csr.com>
Reviewed-by: Barry Song <Baohua.Song@csr.com>
Acked-by: Myungjoo Ham <myungjoo.ham@samsung.com>
Signed-off-by: Chanwoo Choi <cw00.choi@samsung.com>
drivers/extcon/extcon-gpio.c
include/linux/extcon/extcon-gpio.h

index 4736a9c57efa05aef4146b87c7c953557c2a769b..a63a6b21c9ad4a539e311ff17899491922efaa54 100644 (file)
@@ -40,6 +40,7 @@ struct gpio_extcon_data {
        int irq;
        struct delayed_work work;
        unsigned long debounce_jiffies;
+       bool check_on_resume;
 };
 
 static void gpio_extcon_work(struct work_struct *work)
@@ -103,6 +104,7 @@ static int gpio_extcon_probe(struct platform_device *pdev)
        extcon_data->gpio_active_low = pdata->gpio_active_low;
        extcon_data->state_on = pdata->state_on;
        extcon_data->state_off = pdata->state_off;
+       extcon_data->check_on_resume = pdata->check_on_resume;
        if (pdata->state_on && pdata->state_off)
                extcon_data->edev.print_state = extcon_gpio_print_state;
 
@@ -160,12 +162,31 @@ static int gpio_extcon_remove(struct platform_device *pdev)
        return 0;
 }
 
+#ifdef CONFIG_PM_SLEEP
+static int gpio_extcon_resume(struct device *dev)
+{
+       struct gpio_extcon_data *extcon_data;
+
+       extcon_data = dev_get_drvdata(dev);
+       if (extcon_data->check_on_resume)
+               queue_delayed_work(system_power_efficient_wq,
+                       &extcon_data->work, extcon_data->debounce_jiffies);
+
+       return 0;
+}
+#endif
+
+static const struct dev_pm_ops gpio_extcon_pm_ops = {
+       SET_SYSTEM_SLEEP_PM_OPS(NULL, gpio_extcon_resume)
+};
+
 static struct platform_driver gpio_extcon_driver = {
        .probe          = gpio_extcon_probe,
        .remove         = gpio_extcon_remove,
        .driver         = {
                .name   = "extcon-gpio",
                .owner  = THIS_MODULE,
+               .pm     = &gpio_extcon_pm_ops,
        },
 };
 
index 4195810f87fe6a3eda2eaf928b3361cb795626b8..8900fdf511c6acf91f71c67894f32c26cb7fbfbd 100644 (file)
@@ -51,6 +51,7 @@ struct gpio_extcon_platform_data {
        /* if NULL, "0" or "1" will be printed */
        const char *state_on;
        const char *state_off;
+       bool check_on_resume;
 };
 
 #endif /* __EXTCON_GPIO_H__ */