[PATCH] PM: suspend_device_irqs(): don't disable wakeup IRQs
- From: Kevin Hilman <khilman@xxxxxxxxxxxxxxxxxxx>
- Date: Mon, 4 May 2009 17:27:04 -0700
Interrupts that are flagged as wakeup sources via set_irq_wake()
should not be disabled for suspend.
Signed-off-by: Kevin Hilman <khilman@xxxxxxxxxxxxxxxxxxx>
---
kernel/irq/pm.c | 3 +++
1 files changed, 3 insertions(+), 0 deletions(-)
diff --git a/kernel/irq/pm.c b/kernel/irq/pm.c
index 638d8be..99113bd 100644
--- a/kernel/irq/pm.c
+++ b/kernel/irq/pm.c
@@ -28,6 +28,9 @@ void suspend_device_irqs(void)
for_each_irq_desc(irq, desc) {
unsigned long flags;
+ if (desc->status & IRQ_WAKEUP)
+ continue;
+
spin_lock_irqsave(&desc->lock, flags);
__disable_irq(desc, irq, true);
spin_unlock_irqrestore(&desc->lock, flags);
--
1.6.2.2
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
- Follow-Ups:
- Re: [PATCH] PM: suspend_device_irqs(): don't disable wakeup IRQs
- From: Andrew Morton
- Re: [PATCH] PM: suspend_device_irqs(): don't disable wakeup IRQs
- Prev by Date: [patch 5/7] oom: fix possible oom_dump_tasks NULL pointer
- Next by Date: [patch 6/7] oom: move oom_adj value from task_struct to mm_struct
- Previous by thread: [patch 1/7] lowmemorykiller: Only iterate over process list when needed.
- Next by thread: Re: [PATCH] PM: suspend_device_irqs(): don't disable wakeup IRQs
- Index(es):
Relevant Pages
|