Hi Dave,

    I have confirmed the execution has go into
desc <http://lxr.linux.no/linux+*/+code=desc>->irq_data <http://lxr.linux.no/linux+*/+code=irq_data>.chip <http://lxr.linux.no/linux+*/+code=chip>->irq_disable <http://lxr.linux.no/linux+*/+code=irq_disable>(&desc <http://lxr.linux.no/linux+*/+code=desc>->irq_data <http://lxr.linux.no/linux+*/+code=irq_data>);

  However, irq_disable points to kernel/irq/chip.c:default_disable() which do 
nothings.
  Unlike default_enable() which called by enable_irq() will unmask the IRQ 
accordingly.

  I don't understand the reason behind.

BR,
Jacky
        

On 3/3/2011 6:49 AM, Dave Hylands wrote:
Hi Jacky,

Sending to the list as well.

On Tue, Mar 1, 2011 at 1:55 AM, Jacky Lam<[email protected]>  wrote:
Hi,

     It's long before when I want to enable/disable an interrupt, I call
enable_irq()/disable_irq(). However, recently, I do that again.
disable_irq() do nothing. I looked into the code and find disable_irq()
is pointing to a empty function default_disable(). This change is
started from 2.6.20.

     I want to know what should I do if I want to disable an interrupt now?
So disable/enable_irq are nestable, and you're expected to call them
in the order disable/enable.

You need to call enable_irq exactly the same number of times that you
call disable_irq.

If you start wth inerrtupts enabled and do
enable_irq
...do some stuff...
disable_irq

then disable_irq will do nothing since it just decremented the count
that enable_irq incremented.

Another way of looking at it is that disable_irq increments a count,
and enable_irq decrements a count.
The interrupt is only "really" disabled when the count transitions
from 0 to 1, and the interrupt is only "really" enabled when the count
transitions from 1 to 0.

Dave Hylands


_______________________________________________
Kernelnewbies mailing list
[email protected]
http://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies

Reply via email to