diff options
author | Jeff Dike <jdike@addtoit.com> | 2008-02-05 01:30:57 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2008-02-05 12:44:28 -0500 |
commit | d25f2e1235aab716c9fd6ba36c42503627a3a0e3 (patch) | |
tree | 5eaabe739be50f1417707fb6eef2da75dc567a30 /arch/um/os-Linux/skas | |
parent | ee3d9bd4de1ed93d2a7ee41c331ed30a1c7b8acd (diff) |
uml: use ptrace directly in libc code
Some register accessor cleanups -
userspace() was calling restore_registers and save_registers for no
reason, since userspace() is on the libc side of the house, and these
add no value over calling ptrace directly
init_thread_registers and get_safe_registers were the same thing,
so init_thread_registers is gone
Signed-off-by: Jeff Dike <jdike@linux.intel.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'arch/um/os-Linux/skas')
-rw-r--r-- | arch/um/os-Linux/skas/process.c | 11 |
1 files changed, 8 insertions, 3 deletions
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); |