aboutsummaryrefslogtreecommitdiffstats
path: root/arch/tile/include
diff options
context:
space:
mode:
authorChris Metcalf <cmetcalf@ezchip.com>2015-03-23 11:21:23 -0400
committerChris Metcalf <cmetcalf@ezchip.com>2015-04-17 12:58:44 -0400
commitb340c656af6317e28b466996a72cca019d97b42d (patch)
treef8be5b9f7db4146ca8cf8e4288d49b9bc7e6105b /arch/tile/include
parent9088616fb3c4e0d3ec4efb20378691066a218f9c (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/Kbuild1
-rw-r--r--arch/tile/include/asm/irq_work.h14
-rw-r--r--arch/tile/include/asm/smp.h1
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
16generic-y += ioctls.h 16generic-y += ioctls.h
17generic-y += ipcbuf.h 17generic-y += ipcbuf.h
18generic-y += irq_regs.h 18generic-y += irq_regs.h
19generic-y += irq_work.h
20generic-y += local.h 19generic-y += local.h
21generic-y += local64.h 20generic-y += local64.h
22generic-y += mcs_spinlock.h 21generic-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
4static 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. */
74static inline void arch_send_call_function_ipi_mask(struct cpumask *mask) 75static inline void arch_send_call_function_ipi_mask(struct cpumask *mask)