|
@@ -320,11 +320,12 @@ static int spear_kbd_suspend(struct device *dev)
|
|
|
|
|
|
mutex_lock(&input_dev->mutex);
|
|
|
|
|
|
- if (input_dev->users)
|
|
|
- clk_enable(kbd->clk);
|
|
|
-
|
|
|
- if (device_may_wakeup(&pdev->dev))
|
|
|
+ if (device_may_wakeup(&pdev->dev)) {
|
|
|
enable_irq_wake(kbd->irq);
|
|
|
+ } else {
|
|
|
+ if (input_dev->users)
|
|
|
+ clk_disable(kbd->clk);
|
|
|
+ }
|
|
|
|
|
|
mutex_unlock(&input_dev->mutex);
|
|
|
|
|
@@ -339,11 +340,12 @@ static int spear_kbd_resume(struct device *dev)
|
|
|
|
|
|
mutex_lock(&input_dev->mutex);
|
|
|
|
|
|
- if (device_may_wakeup(&pdev->dev))
|
|
|
+ if (device_may_wakeup(&pdev->dev)) {
|
|
|
disable_irq_wake(kbd->irq);
|
|
|
-
|
|
|
- if (input_dev->users)
|
|
|
- clk_enable(kbd->clk);
|
|
|
+ } else {
|
|
|
+ if (input_dev->users)
|
|
|
+ clk_enable(kbd->clk);
|
|
|
+ }
|
|
|
|
|
|
mutex_unlock(&input_dev->mutex);
|
|
|
|