diff options
author | Chris Metcalf <cmetcalf@ezchip.com> | 2015-03-23 11:21:23 -0400 |
---|---|---|
committer | Chris Metcalf <cmetcalf@ezchip.com> | 2015-04-17 12:58:44 -0400 |
commit | b340c656af6317e28b466996a72cca019d97b42d (patch) | |
tree | f8be5b9f7db4146ca8cf8e4288d49b9bc7e6105b /arch/tile/include | |
parent | 9088616fb3c4e0d3ec4efb20378691066a218f9c (diff) |
tile: support arch_irq_work_raise
Tile includes a hypervisor hook to deliver messages to arbitrary
tiles, so we can use that to raise an interrupt as soon as
possible on our own core. Unfortunately the Tilera hypervisor
disabled that support on principle in previous releases, but
it will be available in MDE 4.3.4 and later.
Signed-off-by: Chris Metcalf <cmetcalf@ezchip.com>
Acked-by: Frederic Weisbecker <fweisbec@gmail.com>
Diffstat (limited to 'arch/tile/include')
-rw-r--r-- | arch/tile/include/asm/Kbuild | 1 | ||||
-rw-r--r-- | arch/tile/include/asm/irq_work.h | 14 | ||||
-rw-r--r-- | arch/tile/include/asm/smp.h | 1 |
3 files changed, 15 insertions, 1 deletions
diff --git a/arch/tile/include/asm/Kbuild b/arch/tile/include/asm/Kbuild index b4c488b65745..f5433e0e34e0 100644 --- a/arch/tile/include/asm/Kbuild +++ b/arch/tile/include/asm/Kbuild | |||
@@ -16,7 +16,6 @@ generic-y += ioctl.h | |||
16 | generic-y += ioctls.h | 16 | generic-y += ioctls.h |
17 | generic-y += ipcbuf.h | 17 | generic-y += ipcbuf.h |
18 | generic-y += irq_regs.h | 18 | generic-y += irq_regs.h |
19 | generic-y += irq_work.h | ||
20 | generic-y += local.h | 19 | generic-y += local.h |
21 | generic-y += local64.h | 20 | generic-y += local64.h |
22 | generic-y += mcs_spinlock.h | 21 | generic-y += mcs_spinlock.h |
diff --git a/arch/tile/include/asm/irq_work.h b/arch/tile/include/asm/irq_work.h new file mode 100644 index 000000000000..48af33a61a2c --- /dev/null +++ b/arch/tile/include/asm/irq_work.h | |||
@@ -0,0 +1,14 @@ | |||
1 | #ifndef __ASM_IRQ_WORK_H | ||
2 | #define __ASM_IRQ_WORK_H | ||
3 | |||
4 | static inline bool arch_irq_work_has_interrupt(void) | ||
5 | { | ||
6 | #ifdef CONFIG_SMP | ||
7 | extern bool self_interrupt_ok; | ||
8 | return self_interrupt_ok; | ||
9 | #else | ||
10 | return false; | ||
11 | #endif | ||
12 | } | ||
13 | |||
14 | #endif /* __ASM_IRQ_WORK_H */ | ||
diff --git a/arch/tile/include/asm/smp.h b/arch/tile/include/asm/smp.h index 9a326b64f7ae..735e7f144733 100644 --- a/arch/tile/include/asm/smp.h +++ b/arch/tile/include/asm/smp.h | |||
@@ -69,6 +69,7 @@ static inline int xy_to_cpu(int x, int y) | |||
69 | #define MSG_TAG_STOP_CPU 2 | 69 | #define MSG_TAG_STOP_CPU 2 |
70 | #define MSG_TAG_CALL_FUNCTION_MANY 3 | 70 | #define MSG_TAG_CALL_FUNCTION_MANY 3 |
71 | #define MSG_TAG_CALL_FUNCTION_SINGLE 4 | 71 | #define MSG_TAG_CALL_FUNCTION_SINGLE 4 |
72 | #define MSG_TAG_IRQ_WORK 5 | ||
72 | 73 | ||
73 | /* Hook for the generic smp_call_function_many() routine. */ | 74 | /* Hook for the generic smp_call_function_many() routine. */ |
74 | static inline void arch_send_call_function_ipi_mask(struct cpumask *mask) | 75 | static inline void arch_send_call_function_ipi_mask(struct cpumask *mask) |