|
@@ -39,18 +39,11 @@ NESTED(handle_sys64, PT_SIZE, sp)
|
|
|
.set at
|
|
|
#endif
|
|
|
|
|
|
- dsubu t0, v0, __NR_64_Linux # check syscall number
|
|
|
- sltiu t0, t0, __NR_64_Linux_syscalls + 1
|
|
|
#if !defined(CONFIG_MIPS32_O32) && !defined(CONFIG_MIPS32_N32)
|
|
|
ld t1, PT_EPC(sp) # skip syscall on return
|
|
|
daddiu t1, 4 # skip to next instruction
|
|
|
sd t1, PT_EPC(sp)
|
|
|
#endif
|
|
|
- beqz t0, illegal_syscall
|
|
|
-
|
|
|
- dsll t0, v0, 3 # offset into table
|
|
|
- ld t2, (sys_call_table - (__NR_64_Linux * 8))(t0)
|
|
|
- # syscall routine
|
|
|
|
|
|
sd a3, PT_R26(sp) # save a3 for syscall restarting
|
|
|
|
|
@@ -59,6 +52,17 @@ NESTED(handle_sys64, PT_SIZE, sp)
|
|
|
and t0, t1, t0
|
|
|
bnez t0, syscall_trace_entry
|
|
|
|
|
|
+syscall_common:
|
|
|
+ dsubu t2, v0, __NR_64_Linux
|
|
|
+ sltiu t0, t2, __NR_64_Linux_syscalls + 1
|
|
|
+ beqz t0, illegal_syscall
|
|
|
+
|
|
|
+ dsll t0, t2, 3 # offset into table
|
|
|
+ dla t2, sys_call_table
|
|
|
+ daddu t0, t2, t0
|
|
|
+ ld t2, (t0) # syscall routine
|
|
|
+ beqz t2, illegal_syscall
|
|
|
+
|
|
|
jalr t2 # Do The Real Thing (TM)
|
|
|
|
|
|
li t0, -EMAXERRNO - 1 # error?
|
|
@@ -78,14 +82,14 @@ n64_syscall_exit:
|
|
|
|
|
|
syscall_trace_entry:
|
|
|
SAVE_STATIC
|
|
|
- move s0, t2
|
|
|
+ move s0, v0
|
|
|
move a0, sp
|
|
|
move a1, v0
|
|
|
jal syscall_trace_enter
|
|
|
|
|
|
- bltz v0, 2f # seccomp failed? Skip syscall
|
|
|
+ bltz v0, 1f # seccomp failed? Skip syscall
|
|
|
|
|
|
- move t0, s0
|
|
|
+ move v0, s0
|
|
|
RESTORE_STATIC
|
|
|
ld a0, PT_R4(sp) # Restore argument registers
|
|
|
ld a1, PT_R5(sp)
|
|
@@ -93,19 +97,9 @@ syscall_trace_entry:
|
|
|
ld a3, PT_R7(sp)
|
|
|
ld a4, PT_R8(sp)
|
|
|
ld a5, PT_R9(sp)
|
|
|
- jalr t0
|
|
|
-
|
|
|
- li t0, -EMAXERRNO - 1 # error?
|
|
|
- sltu t0, t0, v0
|
|
|
- sd t0, PT_R7(sp) # set error flag
|
|
|
- beqz t0, 1f
|
|
|
-
|
|
|
- ld t1, PT_R2(sp) # syscall number
|
|
|
- dnegu v0 # error
|
|
|
- sd t1, PT_R0(sp) # save it for syscall restarting
|
|
|
-1: sd v0, PT_R2(sp) # result
|
|
|
+ j syscall_common
|
|
|
|
|
|
-2: j syscall_exit
|
|
|
+1: j syscall_exit
|
|
|
|
|
|
illegal_syscall:
|
|
|
/* This also isn't a 64-bit syscall, throw an error. */
|
|
@@ -436,4 +430,6 @@ EXPORT(sys_call_table)
|
|
|
PTR sys_memfd_create
|
|
|
PTR sys_bpf /* 5315 */
|
|
|
PTR sys_execveat
|
|
|
+ PTR sys_userfaultfd
|
|
|
+ PTR sys_membarrier
|
|
|
.size sys_call_table,.-sys_call_table
|