diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2014-06-04 18:59:13 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-06-04 18:59:13 -0400 |
commit | d09cc3659db494aca4b3bb2393c533fb4946b794 (patch) | |
tree | 158d1dd5fa5fddf1c99da677a193b8561c11274d /include/linux/interrupt.h | |
parent | 82e627eb5e07d7993216c9e63fb5550cf6ed25d7 (diff) | |
parent | c0ffa793994a7a69c37a96dabf38323eae1dffa6 (diff) |
Merge branch 'irq-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip into next
Pull core irq updates from Thomas Gleixner:
"The irq department delivers:
- Another tree wide update to get rid of the horrible create_irq
interface along with its even more horrible variants. That also
gets rid of the last leftovers of the initial sparse irq hackery.
arch/driver specific changes have been either acked or ignored.
- A fix for the spurious interrupt detection logic with threaded
interrupts.
- A new ARM SoC interrupt controller
- The usual pile of fixes and improvements all over the place"
* 'irq-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (40 commits)
Documentation: brcmstb-l2: Add Broadcom STB Level-2 interrupt controller binding
irqchip: brcmstb-l2: Add Broadcom Set Top Box Level-2 interrupt controller
genirq: Improve documentation to match current implementation
ARM: iop13xx: fix msi support with sparse IRQ
genirq: Provide !SMP stub for irq_set_affinity_notifier()
irqchip: armada-370-xp: Move the devicetree binding documentation
irqchip: gic: Use mask field in GICC_IAR
genirq: Remove dynamic_irq mess
ia64: Use irq_init_desc
genirq: Replace dynamic_irq_init/cleanup
genirq: Remove irq_reserve_irq[s]
genirq: Replace reserve_irqs in core code
s390: Avoid call to irq_reserve_irqs()
s390: Remove pointless arch_show_interrupts()
s390: pci: Check return value of alloc_irq_desc() proper
sh: intc: Remove pointless irq_reserve_irqs() invocation
x86, irq: Remove pointless irq_reserve_irqs() call
genirq: Make create/destroy_irq() ia64 private
tile: Use SPARSE_IRQ
tile: pci: Use irq_alloc/free_hwirq()
...
Diffstat (limited to 'include/linux/interrupt.h')
-rw-r--r-- | include/linux/interrupt.h | 46 |
1 files changed, 26 insertions, 20 deletions
diff --git a/include/linux/interrupt.h b/include/linux/interrupt.h index cb19f09d7e3e..698ad053d064 100644 --- a/include/linux/interrupt.h +++ b/include/linux/interrupt.h | |||
@@ -199,6 +199,26 @@ extern int check_wakeup_irqs(void); | |||
199 | static inline int check_wakeup_irqs(void) { return 0; } | 199 | static inline int check_wakeup_irqs(void) { return 0; } |
200 | #endif | 200 | #endif |
201 | 201 | ||
202 | /** | ||
203 | * struct irq_affinity_notify - context for notification of IRQ affinity changes | ||
204 | * @irq: Interrupt to which notification applies | ||
205 | * @kref: Reference count, for internal use | ||
206 | * @work: Work item, for internal use | ||
207 | * @notify: Function to be called on change. This will be | ||
208 | * called in process context. | ||
209 | * @release: Function to be called on release. This will be | ||
210 | * called in process context. Once registered, the | ||
211 | * structure must only be freed when this function is | ||
212 | * called or later. | ||
213 | */ | ||
214 | struct irq_affinity_notify { | ||
215 | unsigned int irq; | ||
216 | struct kref kref; | ||
217 | struct work_struct work; | ||
218 | void (*notify)(struct irq_affinity_notify *, const cpumask_t *mask); | ||
219 | void (*release)(struct kref *ref); | ||
220 | }; | ||
221 | |||
202 | #if defined(CONFIG_SMP) | 222 | #if defined(CONFIG_SMP) |
203 | 223 | ||
204 | extern cpumask_var_t irq_default_affinity; | 224 | extern cpumask_var_t irq_default_affinity; |
@@ -242,26 +262,6 @@ extern int irq_select_affinity(unsigned int irq); | |||
242 | 262 | ||
243 | extern int irq_set_affinity_hint(unsigned int irq, const struct cpumask *m); | 263 | extern int irq_set_affinity_hint(unsigned int irq, const struct cpumask *m); |
244 | 264 | ||
245 | /** | ||
246 | * struct irq_affinity_notify - context for notification of IRQ affinity changes | ||
247 | * @irq: Interrupt to which notification applies | ||
248 | * @kref: Reference count, for internal use | ||
249 | * @work: Work item, for internal use | ||
250 | * @notify: Function to be called on change. This will be | ||
251 | * called in process context. | ||
252 | * @release: Function to be called on release. This will be | ||
253 | * called in process context. Once registered, the | ||
254 | * structure must only be freed when this function is | ||
255 | * called or later. | ||
256 | */ | ||
257 | struct irq_affinity_notify { | ||
258 | unsigned int irq; | ||
259 | struct kref kref; | ||
260 | struct work_struct work; | ||
261 | void (*notify)(struct irq_affinity_notify *, const cpumask_t *mask); | ||
262 | void (*release)(struct kref *ref); | ||
263 | }; | ||
264 | |||
265 | extern int | 265 | extern int |
266 | irq_set_affinity_notifier(unsigned int irq, struct irq_affinity_notify *notify); | 266 | irq_set_affinity_notifier(unsigned int irq, struct irq_affinity_notify *notify); |
267 | 267 | ||
@@ -289,6 +289,12 @@ static inline int irq_set_affinity_hint(unsigned int irq, | |||
289 | { | 289 | { |
290 | return -EINVAL; | 290 | return -EINVAL; |
291 | } | 291 | } |
292 | |||
293 | static inline int | ||
294 | irq_set_affinity_notifier(unsigned int irq, struct irq_affinity_notify *notify) | ||
295 | { | ||
296 | return 0; | ||
297 | } | ||
292 | #endif /* CONFIG_SMP */ | 298 | #endif /* CONFIG_SMP */ |
293 | 299 | ||
294 | /* | 300 | /* |