@@ -297,6 +297,7 @@ static int __devinit tca6416_keypad_prob
}
i2c_set_clientdata(client, chip);
+ device_init_wakeup(&client->dev, 1);
return 0;
@@ -326,10 +327,35 @@ static int __devexit tca6416_keypad_remo
return 0;
}
+static int tca6416_keypad_suspend(struct device *dev)
+{
+ struct tca6416_keypad_chip *chip = dev_get_drvdata(dev);
+
+ if (device_may_wakeup(dev))
+ enable_irq_wake(chip->irqnum);
+
+ return 0;
+}
+
+static int tca6416_keypad_resume(struct device *dev)
+{
+ struct tca6416_keypad_chip *chip = dev_get_drvdata(dev);
+
+ if (device_may_wakeup(dev))
+ disable_irq_wake(chip->irqnum);
+
+ return 0;
+}
+
+static const struct dev_pm_ops tca6416_keypad_dev_pm_ops = {
+ .suspend = tca6416_keypad_suspend,
+ .resume = tca6416_keypad_resume,
+};
static struct i2c_driver tca6416_keypad_driver = {
.driver = {
.name = "tca6416-keypad",
+ .pm = &tca6416_keypad_dev_pm_ops,
},
.probe = tca6416_keypad_probe,
.remove = __devexit_p(tca6416_keypad_remove),