diff options
Diffstat (limited to 'arch/um/os-Linux')
-rw-r--r-- | arch/um/os-Linux/registers.c | 13 | ||||
-rw-r--r-- | arch/um/os-Linux/skas/process.c | 11 |
2 files changed, 12 insertions, 12 deletions
diff --git a/arch/um/os-Linux/registers.c b/arch/um/os-Linux/registers.c index a32ba6ab1211..c78fae3aba81 100644 --- a/arch/um/os-Linux/registers.c +++ b/arch/um/os-Linux/registers.c | |||
@@ -10,15 +10,6 @@ | |||
10 | #include "sysdep/ptrace.h" | 10 | #include "sysdep/ptrace.h" |
11 | #include "user.h" | 11 | #include "user.h" |
12 | 12 | ||
13 | /* This is set once at boot time and not changed thereafter */ | ||
14 | |||
15 | static unsigned long exec_regs[MAX_REG_NR]; | ||
16 | |||
17 | void init_thread_registers(struct uml_pt_regs *to) | ||
18 | { | ||
19 | memcpy(to->gp, exec_regs, sizeof(to->gp)); | ||
20 | } | ||
21 | |||
22 | void save_registers(int pid, struct uml_pt_regs *regs) | 13 | void save_registers(int pid, struct uml_pt_regs *regs) |
23 | { | 14 | { |
24 | int err; | 15 | int err; |
@@ -39,6 +30,10 @@ void restore_registers(int pid, struct uml_pt_regs *regs) | |||
39 | "errno = %d\n", errno); | 30 | "errno = %d\n", errno); |
40 | } | 31 | } |
41 | 32 | ||
33 | /* This is set once at boot time and not changed thereafter */ | ||
34 | |||
35 | static unsigned long exec_regs[MAX_REG_NR]; | ||
36 | |||
42 | void init_registers(int pid) | 37 | void init_registers(int pid) |
43 | { | 38 | { |
44 | int err; | 39 | int err; |
diff --git a/arch/um/os-Linux/skas/process.c b/arch/um/os-Linux/skas/process.c index 2cc2071112bc..7dc24e3cb190 100644 --- a/arch/um/os-Linux/skas/process.c +++ b/arch/um/os-Linux/skas/process.c | |||
@@ -300,7 +300,9 @@ void userspace(struct uml_pt_regs *regs) | |||
300 | nsecs += os_nsecs(); | 300 | nsecs += os_nsecs(); |
301 | 301 | ||
302 | while (1) { | 302 | while (1) { |
303 | restore_registers(pid, regs); | 303 | if (ptrace(PTRACE_SETREGS, pid, 0, regs->gp)) |
304 | panic("userspace - PTRACE_SETREGS failed, " | ||
305 | "errno = %d\n", errno); | ||
304 | 306 | ||
305 | /* Now we set local_using_sysemu to be used for one loop */ | 307 | /* Now we set local_using_sysemu to be used for one loop */ |
306 | local_using_sysemu = get_using_sysemu(); | 308 | local_using_sysemu = get_using_sysemu(); |
@@ -320,7 +322,10 @@ void userspace(struct uml_pt_regs *regs) | |||
320 | errno); | 322 | errno); |
321 | 323 | ||
322 | regs->is_user = 1; | 324 | regs->is_user = 1; |
323 | save_registers(pid, regs); | 325 | if (ptrace(PTRACE_GETREGS, pid, 0, regs->gp)) |
326 | panic("userspace - saving registers failed, " | ||
327 | "errno = %d\n", errno); | ||
328 | |||
324 | UPT_SYSCALL_NR(regs) = -1; /* Assume: It's not a syscall */ | 329 | UPT_SYSCALL_NR(regs) = -1; /* Assume: It's not a syscall */ |
325 | 330 | ||
326 | if (WIFSTOPPED(status)) { | 331 | if (WIFSTOPPED(status)) { |
@@ -343,7 +348,7 @@ void userspace(struct uml_pt_regs *regs) | |||
343 | break; | 348 | break; |
344 | case SIGVTALRM: | 349 | case SIGVTALRM: |
345 | now = os_nsecs(); | 350 | now = os_nsecs(); |
346 | if(now < nsecs) | 351 | if (now < nsecs) |
347 | break; | 352 | break; |
348 | block_signals(); | 353 | block_signals(); |
349 | (*sig_info[sig])(sig, regs); | 354 | (*sig_info[sig])(sig, regs); |