Lines Matching full:irq
20 #include <asm/irq.h>
41 * irq handling routines.
43 * IRQF_SHARED - allow sharing the irq among several devices
47 * IRQF_NOBALANCING - Flag to exclude this interrupt from irq balancing
53 * irq line disabled until the threaded handler has been run.
54 * IRQF_NO_SUSPEND - Do not disable this IRQ during suspend. Does not guarantee
59 * IRQF_EARLY_RESUME - Resume IRQ early during syscore instead of at device
61 * IRQF_COND_SUSPEND - If the IRQ is shared with a NO_SUSPEND user, execute this
65 * IRQF_NO_AUTOEN - Don't enable IRQ or NMI automatically when users request it.
109 * @irq: interrupt number
116 * @dir: pointer to the proc/irq/NN/name entry
126 unsigned int irq; member
137 * If a (PCI) device interrupt is not connected we set dev->irq to
147 request_threaded_irq(unsigned int irq, irq_handler_t handler,
153 * @irq: The interrupt line to allocate
154 * @handler: Function to be called when the IRQ occurs.
165 request_irq(unsigned int irq, irq_handler_t handler, unsigned long flags, in request_irq() argument
168 return request_threaded_irq(irq, handler, NULL, flags, name, dev); in request_irq()
172 request_any_context_irq(unsigned int irq, irq_handler_t handler,
176 __request_percpu_irq(unsigned int irq, irq_handler_t handler,
181 request_nmi(unsigned int irq, irq_handler_t handler, unsigned long flags,
185 request_percpu_irq(unsigned int irq, irq_handler_t handler, in request_percpu_irq() argument
188 return __request_percpu_irq(irq, handler, 0, in request_percpu_irq()
193 request_percpu_nmi(unsigned int irq, irq_handler_t handler,
199 extern const void *free_nmi(unsigned int irq, void *dev_id);
200 extern void free_percpu_nmi(unsigned int irq, void __percpu *percpu_dev_id);
205 devm_request_threaded_irq(struct device *dev, unsigned int irq,
211 devm_request_irq(struct device *dev, unsigned int irq, irq_handler_t handler, in devm_request_irq() argument
214 return devm_request_threaded_irq(dev, irq, handler, NULL, irqflags, in devm_request_irq()
219 devm_request_any_context_irq(struct device *dev, unsigned int irq,
223 extern void devm_free_irq(struct device *dev, unsigned int irq, void *dev_id);
225 bool irq_has_action(unsigned int irq);
226 extern void disable_irq_nosync(unsigned int irq);
227 extern bool disable_hardirq(unsigned int irq);
228 extern void disable_irq(unsigned int irq);
229 extern void disable_percpu_irq(unsigned int irq);
230 extern void enable_irq(unsigned int irq);
231 extern void enable_percpu_irq(unsigned int irq, unsigned int type);
232 extern bool irq_percpu_is_enabled(unsigned int irq);
233 extern void irq_wake_thread(unsigned int irq, void *dev_id);
235 extern void disable_nmi_nosync(unsigned int irq);
236 extern void disable_percpu_nmi(unsigned int irq);
237 extern void enable_nmi(unsigned int irq);
238 extern void enable_percpu_nmi(unsigned int irq, unsigned int type);
239 extern int prepare_percpu_nmi(unsigned int irq);
240 extern void teardown_percpu_nmi(unsigned int irq);
242 extern int irq_inject_interrupt(unsigned int irq);
247 extern void rearm_wake_irq(unsigned int irq);
250 * struct irq_affinity_notify - context for notification of IRQ affinity changes
251 * @irq: Interrupt to which notification applies
262 unsigned int irq; member
272 * struct irq_affinity - Description for automatic irq affinity assignements
308 extern int irq_set_affinity(unsigned int irq, const struct cpumask *cpumask);
309 extern int irq_force_affinity(unsigned int irq, const struct cpumask *cpumask);
311 extern int irq_can_set_affinity(unsigned int irq);
312 extern int irq_select_affinity(unsigned int irq);
314 extern int __irq_apply_affinity_hint(unsigned int irq, const struct cpumask *m,
319 * @irq: Interrupt to update
325 irq_update_affinity_hint(unsigned int irq, const struct cpumask *m) in irq_update_affinity_hint() argument
327 return __irq_apply_affinity_hint(irq, m, false); in irq_update_affinity_hint()
333 * @irq: Interrupt to update
340 irq_set_affinity_and_hint(unsigned int irq, const struct cpumask *m) in irq_set_affinity_and_hint() argument
342 return __irq_apply_affinity_hint(irq, m, true); in irq_set_affinity_and_hint()
349 static inline int irq_set_affinity_hint(unsigned int irq, const struct cpumask *m) in irq_set_affinity_hint() argument
351 return irq_set_affinity_and_hint(irq, m); in irq_set_affinity_hint()
354 extern int irq_update_affinity_desc(unsigned int irq,
358 irq_set_affinity_notifier(unsigned int irq, struct irq_affinity_notify *notify);
368 static inline int irq_set_affinity(unsigned int irq, const struct cpumask *m) in irq_set_affinity() argument
373 static inline int irq_force_affinity(unsigned int irq, const struct cpumask *cpumask) in irq_force_affinity() argument
378 static inline int irq_can_set_affinity(unsigned int irq) in irq_can_set_affinity() argument
383 static inline int irq_select_affinity(unsigned int irq) { return 0; } in irq_select_affinity() argument
385 static inline int irq_update_affinity_hint(unsigned int irq, in irq_update_affinity_hint() argument
391 static inline int irq_set_affinity_and_hint(unsigned int irq, in irq_set_affinity_and_hint() argument
397 static inline int irq_set_affinity_hint(unsigned int irq, in irq_set_affinity_hint() argument
403 static inline int irq_update_affinity_desc(unsigned int irq, in irq_update_affinity_desc() argument
410 irq_set_affinity_notifier(unsigned int irq, struct irq_affinity_notify *notify) in irq_set_affinity_notifier() argument
431 * Special lockdep variants of irq disabling/enabling.
433 * know that a particular irq context which is disabled,
434 * and which is the only irq-context user of a lock,
435 * that it's safe to take the lock in the irq-disabled
439 * irq disable/enable methods.
441 static inline void disable_irq_nosync_lockdep(unsigned int irq) in disable_irq_nosync_lockdep() argument
443 disable_irq_nosync(irq); in disable_irq_nosync_lockdep()
449 static inline void disable_irq_nosync_lockdep_irqsave(unsigned int irq, unsigned long *flags) in disable_irq_nosync_lockdep_irqsave() argument
451 disable_irq_nosync(irq); in disable_irq_nosync_lockdep_irqsave()
457 static inline void disable_irq_lockdep(unsigned int irq) in disable_irq_lockdep() argument
459 disable_irq(irq); in disable_irq_lockdep()
465 static inline void enable_irq_lockdep(unsigned int irq) in enable_irq_lockdep() argument
470 enable_irq(irq); in enable_irq_lockdep()
473 static inline void enable_irq_lockdep_irqrestore(unsigned int irq, unsigned long *flags) in enable_irq_lockdep_irqrestore() argument
478 enable_irq(irq); in enable_irq_lockdep_irqrestore()
481 /* IRQ wakeup (PM) control: */
482 extern int irq_set_irq_wake(unsigned int irq, unsigned int on);
484 static inline int enable_irq_wake(unsigned int irq) in enable_irq_wake() argument
486 return irq_set_irq_wake(irq, 1); in enable_irq_wake()
489 static inline int disable_irq_wake(unsigned int irq) in disable_irq_wake() argument
491 return irq_set_irq_wake(irq, 0); in disable_irq_wake()
501 IRQCHIP_STATE_LINE_LEVEL, /* Is IRQ line high? */
504 extern int irq_get_irqchip_state(unsigned int irq, enum irqchip_irq_state which,
506 extern int irq_set_irqchip_state(unsigned int irq, enum irqchip_irq_state which,
759 * for accurate IRQ probing during kernel initialization. They are
761 * and, unlike other attempts at IRQ probing, they do not get hung on
771 * 6. irq = probe_irq_off(irqs); // get IRQ number, 0=none, negative=multiple
775 * probe_irq_on() returns a mask of allocated irq's.
778 * and returns the irq number which occurred,
779 * or zero if none occurred, or a negative irq number
780 * if more than one irq occurred.
803 /* Initialize /proc/irq/ */