2
0
mirror of https://github.com/checkpoint-restore/criu synced 2025-08-31 14:25:49 +00:00

arm: don't use the register R12 in the routine syscall_common()

The register R12 has a special meaning when syscalls are hooked
with ptrace() in ARM that results in a dumpee context corruption
on an injected blob unmap. Note that this patch doesn't solve
the problem entirely since the compiler may corrupt the register
before issuing a call to the routine sys_munmap(); however
we assume that a sufficiently decent compiler doesn't.

Signed-off-by: Alexander Kartashov <alekskartashov@parallels.com>
Tested-by: Andrew Vagin <avagin@parallels.com>
Signed-off-by: Pavel Emelyanov <xemul@parallels.com>
This commit is contained in:
Alexander Kartashov
2013-09-26 15:56:35 +04:00
committed by Pavel Emelyanov
parent 4e2031ca64
commit 8f74187af1

View File

@@ -1,12 +1,18 @@
#include "asm/linkage.h"
@ We use the register R8 unlike libc that uses R12.
@ This avoids corruption of the register by the stub
@ for the syscall sys_munmap() when syscalls are hooked
@ by ptrace(). However we have to make sure that
@ the compiler doesn't use the register on the route
@ between parasite_service() and sys_munmap().
syscall_common:
ldr %r7, [%r7]
add %ip, %sp, #16
ldm %ip, {%r4, %r5, %r6}
add %r8, %sp, #24
ldm %r8, {%r4, %r5, %r6}
svc 0x00000000
pop {%r4, %r5, %r6, %r7}
bx %lr
pop {%r4, %r5, %r6, %r7, %r8, %pc}
.macro syscall name, nr
@@ -14,7 +20,7 @@ syscall_common:
.long \nr
ENTRY(\name)
push {%r4, %r5, %r6, %r7}
push {%r4, %r5, %r6, %r7, %r8, %lr}
adr %r7, .nr_\name
b syscall_common
END(\name)