>-----Original Message-----
>From: ext Kevin Hilman [mailto:khil...@deeprootsystems.com] 
>Sent: 21 October, 2009 17:20
>To: Kristo Tero (Nokia-D/Tampere)
>Cc: linux-omap@vger.kernel.org
>Subject: Re: [PATCH 09/17] OMAP3: PM: Ack pending interrupts 
>before entering suspend
>
><tero.kri...@nokia.com> writes:
>
>>>-----Original Message-----
>>>From: linux-omap-ow...@vger.kernel.org 
>>>[mailto:linux-omap-ow...@vger.kernel.org] On Behalf Of ext 
>Kevin Hilman
>>>Sent: 20 October, 2009 20:31
>>>To: Kristo Tero (Nokia-D/Tampere)
>>>Cc: linux-omap@vger.kernel.org
>>>Subject: Re: [PATCH 09/17] OMAP3: PM: Ack pending interrupts 
>>>before entering suspend
>>>
>>>Tero Kristo <tero.kri...@nokia.com> writes:
>>>
>>>> From: Tero Kristo <tero.kri...@nokia.com>
>>>>
>>>> Suspending drivers may still generate interrupts just before 
>>>their suspend is
>>>> completed. Any pending interrupts here will prevent sleep.
>>>>
>>>> Signed-off-by: Tero Kristo <tero.kri...@nokia.com>
>>>
>>>This could also be done in omap3_intc_prepare_idle() hook.
>>
>> I thought it is better to do this in suspend path only, because in
>> normal sleep case we most likely don't want to miss any
>> interrupts. 
>
>Agreed, then I'd suggest doing this in omap3_intc_[suspend|resume]()
>hooks.
>
>> In suspend case, we usually want to enter the suspend no
>> matter what, and this is used here only to clean up the mess left by
>> some of the drivers. The GPT case is one of the main things we try
>> to fix here.
>
>So is this still needed with the GPTIMER fix in PATCH 8/17?

Yeah, it is not enough to ack the interrupt at module level, we still have the 
pending IRQ in the interrupt controller itself.

>
>If there are other drivers having delayed interrupt triggering, it
>sounds like the drivers need to be fixed instead of this brute force
>approach.

I think any system device can have similar issue if they receive an interrupt 
while we are entering suspend. The main problem is the sequence executed during 
suspend: interrupts are disabled before we suspend the system devices (e.g. 
clock source) and it is very possible for the devices to receive interrupts 
during this window. GPT is a special case because it also has internal 
buffering for the register writes, so it continues to tick a while after it is 
stopped. GPT is also special in a sense that it can trigger an interrupt at 
arbitrary points of time.

I don't know if similar issue exists on other platforms so changing the suspend 
sequence itself is probably not an option. And.. acking all interrupts at every 
suspending device is probably neither.

-Tero

>
>>
>>>
>>>> ---
>>>>  arch/arm/mach-omap2/irq.c              |    2 +-
>>>>  arch/arm/mach-omap2/pm34xx.c           |    2 ++
>>>>  arch/arm/plat-omap/include/mach/irqs.h |    1 +
>>>>  3 files changed, 4 insertions(+), 1 deletions(-)
>>>>
>>>> diff --git a/arch/arm/mach-omap2/irq.c b/arch/arm/mach-omap2/irq.c
>>>> index aceedd8..4ed05e9 100644
>>>> --- a/arch/arm/mach-omap2/irq.c
>>>> +++ b/arch/arm/mach-omap2/irq.c
>>>> @@ -101,7 +101,7 @@ static int 
>omap_check_spurious(unsigned int irq)
>>>>  }
>>>>  
>>>>  /* XXX: FIQ and additional INTC support (only MPU at the 
>moment) */
>>>> -static void omap_ack_irq(unsigned int irq)
>>>> +void omap_ack_irq(unsigned int irq)
>>>>  {
>>>>    intc_bank_write_reg(0x1, &irq_banks[0], INTC_CONTROL);
>>>>  }
>>>> diff --git a/arch/arm/mach-omap2/pm34xx.c 
>>>b/arch/arm/mach-omap2/pm34xx.c
>>>> index 5854fa7..6a41811 100644
>>>> --- a/arch/arm/mach-omap2/pm34xx.c
>>>> +++ b/arch/arm/mach-omap2/pm34xx.c
>>>> @@ -778,6 +778,8 @@ static int omap3_pm_suspend(void)
>>>>  
>>>>    omap_uart_prepare_suspend();
>>>>  
>>>> +  /* Ack pending IRQs, as a pending IRQ will cause the 
>>>suspend to fail */
>>>> +  omap_ack_irq(0);
>>>>    regset_save_on_suspend = 1;
>>>>    omap_sram_idle();
>>>>    regset_save_on_suspend = 0;
>>>> diff --git a/arch/arm/plat-omap/include/mach/irqs.h 
>>>b/arch/arm/plat-omap/include/mach/irqs.h
>>>> index 2473910..d56be1c 100644
>>>> --- a/arch/arm/plat-omap/include/mach/irqs.h
>>>> +++ b/arch/arm/plat-omap/include/mach/irqs.h
>>>> @@ -483,6 +483,7 @@
>>>>  #ifndef __ASSEMBLY__
>>>>  extern void omap_init_irq(void);
>>>>  extern int omap_irq_pending(void);
>>>> +extern void omap_ack_irq(unsigned int irq);
>>>>  void omap3_intc_save_context(void);
>>>>  void omap3_intc_restore_context(void);
>>>>  #endif
>>>> -- 
>>>> 1.5.4.3
>>>>
>>>> --
>>>> To unsubscribe from this list: send the line "unsubscribe 
>>>linux-omap" in
>>>> the body of a message to majord...@vger.kernel.org
>>>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>>>--
>>>To unsubscribe from this list: send the line "unsubscribe 
>>>linux-omap" in
>>>the body of a message to majord...@vger.kernel.org
>>>More majordomo info at  http://vger.kernel.org/majordomo-info.html
>>>
>--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to