|
@@ -9,18 +9,22 @@
|
|
|
|
|
|
#include <linux/linkage.h>
|
|
|
#include <asm/asm-offsets.h>
|
|
|
+#include <asm/nospec-insn.h>
|
|
|
#include <asm/ptrace.h>
|
|
|
#include <asm/sigp.h>
|
|
|
|
|
|
+ GEN_BR_THUNK %r9
|
|
|
+ GEN_BR_THUNK %r14
|
|
|
+
|
|
|
ENTRY(s390_base_mcck_handler)
|
|
|
basr %r13,0
|
|
|
0: lg %r15,__LC_PANIC_STACK # load panic stack
|
|
|
aghi %r15,-STACK_FRAME_OVERHEAD
|
|
|
larl %r1,s390_base_mcck_handler_fn
|
|
|
- lg %r1,0(%r1)
|
|
|
- ltgr %r1,%r1
|
|
|
+ lg %r9,0(%r1)
|
|
|
+ ltgr %r9,%r9
|
|
|
jz 1f
|
|
|
- basr %r14,%r1
|
|
|
+ BASR_EX %r14,%r9
|
|
|
1: la %r1,4095
|
|
|
lmg %r0,%r15,__LC_GPREGS_SAVE_AREA-4095(%r1)
|
|
|
lpswe __LC_MCK_OLD_PSW
|
|
@@ -37,10 +41,10 @@ ENTRY(s390_base_ext_handler)
|
|
|
basr %r13,0
|
|
|
0: aghi %r15,-STACK_FRAME_OVERHEAD
|
|
|
larl %r1,s390_base_ext_handler_fn
|
|
|
- lg %r1,0(%r1)
|
|
|
- ltgr %r1,%r1
|
|
|
+ lg %r9,0(%r1)
|
|
|
+ ltgr %r9,%r9
|
|
|
jz 1f
|
|
|
- basr %r14,%r1
|
|
|
+ BASR_EX %r14,%r9
|
|
|
1: lmg %r0,%r15,__LC_SAVE_AREA_ASYNC
|
|
|
ni __LC_EXT_OLD_PSW+1,0xfd # clear wait state bit
|
|
|
lpswe __LC_EXT_OLD_PSW
|
|
@@ -57,10 +61,10 @@ ENTRY(s390_base_pgm_handler)
|
|
|
basr %r13,0
|
|
|
0: aghi %r15,-STACK_FRAME_OVERHEAD
|
|
|
larl %r1,s390_base_pgm_handler_fn
|
|
|
- lg %r1,0(%r1)
|
|
|
- ltgr %r1,%r1
|
|
|
+ lg %r9,0(%r1)
|
|
|
+ ltgr %r9,%r9
|
|
|
jz 1f
|
|
|
- basr %r14,%r1
|
|
|
+ BASR_EX %r14,%r9
|
|
|
lmg %r0,%r15,__LC_SAVE_AREA_SYNC
|
|
|
lpswe __LC_PGM_OLD_PSW
|
|
|
1: lpswe disabled_wait_psw-0b(%r13)
|
|
@@ -117,7 +121,7 @@ ENTRY(diag308_reset)
|
|
|
larl %r4,.Lcontinue_psw # Restore PSW flags
|
|
|
lpswe 0(%r4)
|
|
|
.Lcontinue:
|
|
|
- br %r14
|
|
|
+ BR_EX %r14
|
|
|
.align 16
|
|
|
.Lrestart_psw:
|
|
|
.long 0x00080000,0x80000000 + .Lrestart_part2
|