2 * linux/kernel/irq/chip.c
4 * Copyright (C) 1992, 1998-2006 Linus Torvalds, Ingo Molnar
5 * Copyright (C) 2005-2006, Thomas Gleixner, Russell King
7 * This file contains the core interrupt handling code, for irq-chip
10 * Detailed information is available in Documentation/DocBook/genericirq
13 #include <linux/irq.h>
14 #include <linux/module.h>
15 #include <linux/interrupt.h>
16 #include <linux/kernel_stat.h>
18 #include "internals.h"
21 * set_irq_chip - set the irq chip for an irq
23 * @chip: pointer to irq chip description structure
25 int set_irq_chip(unsigned int irq
, struct irq_chip
*chip
)
27 struct irq_desc
*desc
;
31 printk(KERN_ERR
"Trying to install chip for IRQ%d\n", irq
);
39 desc
= irq_desc
+ irq
;
40 spin_lock_irqsave(&desc
->lock
, flags
);
41 irq_chip_set_defaults(chip
);
44 * For compatibility only:
47 spin_unlock_irqrestore(&desc
->lock
, flags
);
51 EXPORT_SYMBOL(set_irq_chip
);
54 * set_irq_type - set the irq type for an irq
56 * @type: interrupt type - see include/linux/interrupt.h
58 int set_irq_type(unsigned int irq
, unsigned int type
)
60 struct irq_desc
*desc
;
65 printk(KERN_ERR
"Trying to set irq type for IRQ%d\n", irq
);
69 desc
= irq_desc
+ irq
;
70 if (desc
->chip
->set_type
) {
71 spin_lock_irqsave(&desc
->lock
, flags
);
72 ret
= desc
->chip
->set_type(irq
, type
);
73 spin_unlock_irqrestore(&desc
->lock
, flags
);
77 EXPORT_SYMBOL(set_irq_type
);
80 * set_irq_data - set irq type data for an irq
81 * @irq: Interrupt number
82 * @data: Pointer to interrupt specific data
84 * Set the hardware irq controller data for an irq
86 int set_irq_data(unsigned int irq
, void *data
)
88 struct irq_desc
*desc
;
93 "Trying to install controller data for IRQ%d\n", irq
);
97 desc
= irq_desc
+ irq
;
98 spin_lock_irqsave(&desc
->lock
, flags
);
99 desc
->handler_data
= data
;
100 spin_unlock_irqrestore(&desc
->lock
, flags
);
103 EXPORT_SYMBOL(set_irq_data
);
106 * set_irq_chip_data - set irq chip data for an irq
107 * @irq: Interrupt number
108 * @data: Pointer to chip specific data
110 * Set the hardware irq chip data for an irq
112 int set_irq_chip_data(unsigned int irq
, void *data
)
114 struct irq_desc
*desc
= irq_desc
+ irq
;
117 if (irq
>= NR_IRQS
|| !desc
->chip
) {
118 printk(KERN_ERR
"BUG: bad set_irq_chip_data(IRQ#%d)\n", irq
);
122 spin_lock_irqsave(&desc
->lock
, flags
);
123 desc
->chip_data
= data
;
124 spin_unlock_irqrestore(&desc
->lock
, flags
);
128 EXPORT_SYMBOL(set_irq_chip_data
);
131 * default enable function
133 static void default_enable(unsigned int irq
)
135 struct irq_desc
*desc
= irq_desc
+ irq
;
137 desc
->chip
->unmask(irq
);
138 desc
->status
&= ~IRQ_MASKED
;
142 * default disable function
144 static void default_disable(unsigned int irq
)
146 struct irq_desc
*desc
= irq_desc
+ irq
;
148 if (!(desc
->status
& IRQ_DELAYED_DISABLE
))
149 irq_desc
[irq
].chip
->mask(irq
);
153 * default startup function
155 static unsigned int default_startup(unsigned int irq
)
157 irq_desc
[irq
].chip
->enable(irq
);
163 * Fixup enable/disable function pointers
165 void irq_chip_set_defaults(struct irq_chip
*chip
)
168 chip
->enable
= default_enable
;
170 chip
->disable
= default_disable
;
172 chip
->startup
= default_startup
;
174 chip
->shutdown
= chip
->disable
;
176 chip
->name
= chip
->typename
;
179 static inline void mask_ack_irq(struct irq_desc
*desc
, int irq
)
181 if (desc
->chip
->mask_ack
)
182 desc
->chip
->mask_ack(irq
);
184 desc
->chip
->mask(irq
);
185 desc
->chip
->ack(irq
);
190 * handle_simple_irq - Simple and software-decoded IRQs.
191 * @irq: the interrupt number
192 * @desc: the interrupt description structure for this irq
193 * @regs: pointer to a register structure
195 * Simple interrupts are either sent from a demultiplexing interrupt
196 * handler or come from hardware, where no interrupt hardware control
199 * Note: The caller is expected to handle the ack, clear, mask and
200 * unmask issues if necessary.
203 handle_simple_irq(unsigned int irq
, struct irq_desc
*desc
, struct pt_regs
*regs
)
205 struct irqaction
*action
;
206 irqreturn_t action_ret
;
207 const unsigned int cpu
= smp_processor_id();
209 spin_lock(&desc
->lock
);
211 if (unlikely(desc
->status
& IRQ_INPROGRESS
))
213 desc
->status
&= ~(IRQ_REPLAY
| IRQ_WAITING
);
214 kstat_cpu(cpu
).irqs
[irq
]++;
216 action
= desc
->action
;
217 if (unlikely(!action
|| (desc
->status
& IRQ_DISABLED
)))
220 desc
->status
|= IRQ_INPROGRESS
;
221 spin_unlock(&desc
->lock
);
223 action_ret
= handle_IRQ_event(irq
, regs
, action
);
225 note_interrupt(irq
, desc
, action_ret
, regs
);
227 spin_lock(&desc
->lock
);
228 desc
->status
&= ~IRQ_INPROGRESS
;
230 spin_unlock(&desc
->lock
);
234 * handle_level_irq - Level type irq handler
235 * @irq: the interrupt number
236 * @desc: the interrupt description structure for this irq
237 * @regs: pointer to a register structure
239 * Level type interrupts are active as long as the hardware line has
240 * the active level. This may require to mask the interrupt and unmask
241 * it after the associated handler has acknowledged the device, so the
242 * interrupt line is back to inactive.
245 handle_level_irq(unsigned int irq
, struct irq_desc
*desc
, struct pt_regs
*regs
)
247 unsigned int cpu
= smp_processor_id();
248 struct irqaction
*action
;
249 irqreturn_t action_ret
;
251 spin_lock(&desc
->lock
);
252 mask_ack_irq(desc
, irq
);
254 if (unlikely(desc
->status
& IRQ_INPROGRESS
))
256 desc
->status
&= ~(IRQ_REPLAY
| IRQ_WAITING
);
257 kstat_cpu(cpu
).irqs
[irq
]++;
260 * If its disabled or no action available
261 * keep it masked and get out of here
263 action
= desc
->action
;
264 if (unlikely(!action
|| (desc
->status
& IRQ_DISABLED
)))
267 desc
->status
|= IRQ_INPROGRESS
;
268 spin_unlock(&desc
->lock
);
270 action_ret
= handle_IRQ_event(irq
, regs
, action
);
272 note_interrupt(irq
, desc
, action_ret
, regs
);
274 spin_lock(&desc
->lock
);
275 desc
->status
&= ~IRQ_INPROGRESS
;
277 if (!(desc
->status
& IRQ_DISABLED
) && desc
->chip
->unmask
)
278 desc
->chip
->unmask(irq
);
279 spin_unlock(&desc
->lock
);
283 * handle_fasteoi_irq - irq handler for transparent controllers
284 * @irq: the interrupt number
285 * @desc: the interrupt description structure for this irq
286 * @regs: pointer to a register structure
288 * Only a single callback will be issued to the chip: an ->eoi()
289 * call when the interrupt has been serviced. This enables support
290 * for modern forms of interrupt handlers, which handle the flow
291 * details in hardware, transparently.
294 handle_fasteoi_irq(unsigned int irq
, struct irq_desc
*desc
,
295 struct pt_regs
*regs
)
297 unsigned int cpu
= smp_processor_id();
298 struct irqaction
*action
;
299 irqreturn_t action_ret
;
301 spin_lock(&desc
->lock
);
303 if (unlikely(desc
->status
& IRQ_INPROGRESS
))
306 desc
->status
&= ~(IRQ_REPLAY
| IRQ_WAITING
);
307 kstat_cpu(cpu
).irqs
[irq
]++;
310 * If its disabled or no action available
311 * keep it masked and get out of here
313 action
= desc
->action
;
314 if (unlikely(!action
|| (desc
->status
& IRQ_DISABLED
))) {
315 desc
->status
|= IRQ_PENDING
;
319 desc
->status
|= IRQ_INPROGRESS
;
320 desc
->status
&= ~IRQ_PENDING
;
321 spin_unlock(&desc
->lock
);
323 action_ret
= handle_IRQ_event(irq
, regs
, action
);
325 note_interrupt(irq
, desc
, action_ret
, regs
);
327 spin_lock(&desc
->lock
);
328 desc
->status
&= ~IRQ_INPROGRESS
;
330 desc
->chip
->eoi(irq
);
332 spin_unlock(&desc
->lock
);
336 * handle_edge_irq - edge type IRQ handler
337 * @irq: the interrupt number
338 * @desc: the interrupt description structure for this irq
339 * @regs: pointer to a register structure
341 * Interrupt occures on the falling and/or rising edge of a hardware
342 * signal. The occurence is latched into the irq controller hardware
343 * and must be acked in order to be reenabled. After the ack another
344 * interrupt can happen on the same source even before the first one
345 * is handled by the assosiacted event handler. If this happens it
346 * might be necessary to disable (mask) the interrupt depending on the
347 * controller hardware. This requires to reenable the interrupt inside
348 * of the loop which handles the interrupts which have arrived while
349 * the handler was running. If all pending interrupts are handled, the
353 handle_edge_irq(unsigned int irq
, struct irq_desc
*desc
, struct pt_regs
*regs
)
355 const unsigned int cpu
= smp_processor_id();
357 spin_lock(&desc
->lock
);
359 desc
->status
&= ~(IRQ_REPLAY
| IRQ_WAITING
);
362 * If we're currently running this IRQ, or its disabled,
363 * we shouldn't process the IRQ. Mark it pending, handle
364 * the necessary masking and go out
366 if (unlikely((desc
->status
& (IRQ_INPROGRESS
| IRQ_DISABLED
)) ||
368 desc
->status
|= (IRQ_PENDING
| IRQ_MASKED
);
369 mask_ack_irq(desc
, irq
);
373 kstat_cpu(cpu
).irqs
[irq
]++;
375 /* Start handling the irq */
376 desc
->chip
->ack(irq
);
378 /* Mark the IRQ currently in progress.*/
379 desc
->status
|= IRQ_INPROGRESS
;
382 struct irqaction
*action
= desc
->action
;
383 irqreturn_t action_ret
;
385 if (unlikely(!action
)) {
386 desc
->chip
->mask(irq
);
391 * When another irq arrived while we were handling
392 * one, we could have masked the irq.
393 * Renable it, if it was not disabled in meantime.
395 if (unlikely((desc
->status
&
396 (IRQ_PENDING
| IRQ_MASKED
| IRQ_DISABLED
)) ==
397 (IRQ_PENDING
| IRQ_MASKED
))) {
398 desc
->chip
->unmask(irq
);
399 desc
->status
&= ~IRQ_MASKED
;
402 desc
->status
&= ~IRQ_PENDING
;
403 spin_unlock(&desc
->lock
);
404 action_ret
= handle_IRQ_event(irq
, regs
, action
);
406 note_interrupt(irq
, desc
, action_ret
, regs
);
407 spin_lock(&desc
->lock
);
409 } while ((desc
->status
& (IRQ_PENDING
| IRQ_DISABLED
)) == IRQ_PENDING
);
411 desc
->status
&= ~IRQ_INPROGRESS
;
413 spin_unlock(&desc
->lock
);
418 * handle_percpu_IRQ - Per CPU local irq handler
419 * @irq: the interrupt number
420 * @desc: the interrupt description structure for this irq
421 * @regs: pointer to a register structure
423 * Per CPU interrupts on SMP machines without locking requirements
426 handle_percpu_irq(unsigned int irq
, struct irq_desc
*desc
, struct pt_regs
*regs
)
428 irqreturn_t action_ret
;
430 kstat_this_cpu
.irqs
[irq
]++;
433 desc
->chip
->ack(irq
);
435 action_ret
= handle_IRQ_event(irq
, regs
, desc
->action
);
437 note_interrupt(irq
, desc
, action_ret
, regs
);
440 desc
->chip
->eoi(irq
);
443 #endif /* CONFIG_SMP */
446 __set_irq_handler(unsigned int irq
,
447 void fastcall (*handle
)(unsigned int, irq_desc_t
*,
451 struct irq_desc
*desc
;
454 if (irq
>= NR_IRQS
) {
456 "Trying to install type control for IRQ%d\n", irq
);
460 desc
= irq_desc
+ irq
;
463 handle
= handle_bad_irq
;
465 if (desc
->chip
== &no_irq_chip
) {
466 printk(KERN_WARNING
"Trying to install %sinterrupt handler "
467 "for IRQ%d\n", is_chained
? "chained " : " ", irq
);
469 * Some ARM implementations install a handler for really dumb
470 * interrupt hardware without setting an irq_chip. This worked
471 * with the ARM no_irq_chip but the check in setup_irq would
472 * prevent us to setup the interrupt at all. Switch it to
473 * dummy_irq_chip for easy transition.
475 desc
->chip
= &dummy_irq_chip
;
478 spin_lock_irqsave(&desc
->lock
, flags
);
481 if (handle
== handle_bad_irq
) {
482 if (desc
->chip
!= &no_irq_chip
) {
483 desc
->chip
->mask(irq
);
484 desc
->chip
->ack(irq
);
486 desc
->status
|= IRQ_DISABLED
;
489 desc
->handle_irq
= handle
;
491 if (handle
!= handle_bad_irq
&& is_chained
) {
492 desc
->status
&= ~IRQ_DISABLED
;
493 desc
->status
|= IRQ_NOREQUEST
| IRQ_NOPROBE
;
495 desc
->chip
->unmask(irq
);
497 spin_unlock_irqrestore(&desc
->lock
, flags
);
501 set_irq_chip_and_handler(unsigned int irq
, struct irq_chip
*chip
,
502 void fastcall (*handle
)(unsigned int,
506 set_irq_chip(irq
, chip
);
507 __set_irq_handler(irq
, handle
, 0);
511 * Get a descriptive string for the highlevel handler, for
512 * /proc/interrupts output:
515 handle_irq_name(void fastcall (*handle
)(unsigned int, struct irq_desc
*,
518 if (handle
== handle_level_irq
)
520 if (handle
== handle_fasteoi_irq
)
522 if (handle
== handle_edge_irq
)
524 if (handle
== handle_simple_irq
)
527 if (handle
== handle_percpu_irq
)
530 if (handle
== handle_bad_irq
)