diff options
author | Martin Schwidefsky <schwidefsky@de.ibm.com> | 2018-04-24 05:18:49 -0400 |
---|---|---|
committer | Martin Schwidefsky <schwidefsky@de.ibm.com> | 2018-05-07 15:12:42 -0400 |
commit | 9f18fff63cfd6f559daa1eaae60640372c65f84b (patch) | |
tree | b16f137dfd05c94d56c7cd75b9828bea806ced7b | |
parent | 4253b0e0627ee3461e64c2495c616f1c8f6b127b (diff) |
s390: remove indirect branch from do_softirq_own_stack
The inline assembly to call __do_softirq on the irq stack uses
an indirect branch. This can be replaced with a normal relative
branch.
Cc: stable@vger.kernel.org # 4.16
Fixes: f19fbd5ed6 ("s390: introduce execute-trampolines for branches")
Reviewed-by: Hendrik Brueckner <brueckner@linux.vnet.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
-rw-r--r-- | arch/s390/kernel/irq.c | 5 |
1 files changed, 2 insertions, 3 deletions
diff --git a/arch/s390/kernel/irq.c b/arch/s390/kernel/irq.c index 94f2099bceb0..3d17c41074ca 100644 --- a/arch/s390/kernel/irq.c +++ b/arch/s390/kernel/irq.c | |||
@@ -176,10 +176,9 @@ void do_softirq_own_stack(void) | |||
176 | new -= STACK_FRAME_OVERHEAD; | 176 | new -= STACK_FRAME_OVERHEAD; |
177 | ((struct stack_frame *) new)->back_chain = old; | 177 | ((struct stack_frame *) new)->back_chain = old; |
178 | asm volatile(" la 15,0(%0)\n" | 178 | asm volatile(" la 15,0(%0)\n" |
179 | " basr 14,%2\n" | 179 | " brasl 14,__do_softirq\n" |
180 | " la 15,0(%1)\n" | 180 | " la 15,0(%1)\n" |
181 | : : "a" (new), "a" (old), | 181 | : : "a" (new), "a" (old) |
182 | "a" (__do_softirq) | ||
183 | : "0", "1", "2", "3", "4", "5", "14", | 182 | : "0", "1", "2", "3", "4", "5", "14", |
184 | "cc", "memory" ); | 183 | "cc", "memory" ); |
185 | } else { | 184 | } else { |