|
|
@@ -526,11 +526,12 @@ static int imx_keypad_probe(struct platform_device *pdev)
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
-static int __maybe_unused imx_kbd_suspend(struct device *dev)
|
|
|
+static int __maybe_unused imx_kbd_noirq_suspend(struct device *dev)
|
|
|
{
|
|
|
struct platform_device *pdev = to_platform_device(dev);
|
|
|
struct imx_keypad *kbd = platform_get_drvdata(pdev);
|
|
|
struct input_dev *input_dev = kbd->input_dev;
|
|
|
+ unsigned short reg_val = readw(kbd->mmio_base + KPSR);
|
|
|
|
|
|
/* imx kbd can wake up system even clock is disabled */
|
|
|
mutex_lock(&input_dev->mutex);
|
|
|
@@ -540,13 +541,20 @@ static int __maybe_unused imx_kbd_suspend(struct device *dev)
|
|
|
|
|
|
mutex_unlock(&input_dev->mutex);
|
|
|
|
|
|
- if (device_may_wakeup(&pdev->dev))
|
|
|
+ if (device_may_wakeup(&pdev->dev)) {
|
|
|
+ if (reg_val & KBD_STAT_KPKD)
|
|
|
+ reg_val |= KBD_STAT_KRIE;
|
|
|
+ if (reg_val & KBD_STAT_KPKR)
|
|
|
+ reg_val |= KBD_STAT_KDIE;
|
|
|
+ writew(reg_val, kbd->mmio_base + KPSR);
|
|
|
+
|
|
|
enable_irq_wake(kbd->irq);
|
|
|
+ }
|
|
|
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
-static int __maybe_unused imx_kbd_resume(struct device *dev)
|
|
|
+static int __maybe_unused imx_kbd_noirq_resume(struct device *dev)
|
|
|
{
|
|
|
struct platform_device *pdev = to_platform_device(dev);
|
|
|
struct imx_keypad *kbd = platform_get_drvdata(pdev);
|
|
|
@@ -570,7 +578,9 @@ err_clk:
|
|
|
return ret;
|
|
|
}
|
|
|
|
|
|
-static SIMPLE_DEV_PM_OPS(imx_kbd_pm_ops, imx_kbd_suspend, imx_kbd_resume);
|
|
|
+static const struct dev_pm_ops imx_kbd_pm_ops = {
|
|
|
+ SET_NOIRQ_SYSTEM_SLEEP_PM_OPS(imx_kbd_noirq_suspend, imx_kbd_noirq_resume)
|
|
|
+};
|
|
|
|
|
|
static struct platform_driver imx_keypad_driver = {
|
|
|
.driver = {
|