Commit 993ce028 authored by Jeff Dike's avatar Jeff Dike Committed by Linus Torvalds

[PATCH] uml: SYSEMU fixes

From: Bodo Stroesser <bstroesser@fujitsu-siemens.com>

Usage of SYSEMU in TT mode is modified, so that always the
same method is used in do_syscall as has been used before in
ptrace(PTRACE_SYSCALL/SYSEMU, ...)
Signed-off-by: default avatarBodo Stroesser <bstroesser@fujitsu-siemens.com>
Signed-off-by: default avatarJeff Dike <jdike@addtoit.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 6c4c2f9c
...@@ -26,7 +26,7 @@ extern void set_tracing(void *t, int tracing); ...@@ -26,7 +26,7 @@ extern void set_tracing(void *t, int tracing);
extern int is_tracing(void *task); extern int is_tracing(void *task);
extern void syscall_handler(int sig, union uml_pt_regs *regs); extern void syscall_handler(int sig, union uml_pt_regs *regs);
extern void exit_kernel(int pid, void *task); extern void exit_kernel(int pid, void *task);
extern int do_syscall(void *task, int pid, int local_using_sysemu); extern void do_syscall(void *task, int pid, int local_using_sysemu);
extern void do_sigtrap(void *task); extern void do_sigtrap(void *task);
extern int is_valid_pid(int pid); extern int is_valid_pid(int pid);
extern void remap_data(void *segment_start, void *segment_end, int w); extern void remap_data(void *segment_start, void *segment_end, int w);
......
...@@ -48,7 +48,7 @@ void do_sigtrap(void *task) ...@@ -48,7 +48,7 @@ void do_sigtrap(void *task)
UPT_SYSCALL_NR(TASK_REGS(task)) = -1; UPT_SYSCALL_NR(TASK_REGS(task)) = -1;
} }
int do_syscall(void *task, int pid, int local_using_sysemu) void do_syscall(void *task, int pid, int local_using_sysemu)
{ {
unsigned long proc_regs[FRAME_SIZE]; unsigned long proc_regs[FRAME_SIZE];
...@@ -62,14 +62,11 @@ int do_syscall(void *task, int pid, int local_using_sysemu) ...@@ -62,14 +62,11 @@ int do_syscall(void *task, int pid, int local_using_sysemu)
((unsigned long *) PT_IP(proc_regs) <= &_etext)) ((unsigned long *) PT_IP(proc_regs) <= &_etext))
tracer_panic("I'm tracing myself and I can't get out"); tracer_panic("I'm tracing myself and I can't get out");
if(local_using_sysemu) /* syscall number -1 in sysemu skips syscall restarting in host */
return(1);
if(ptrace(PTRACE_POKEUSER, pid, PT_SYSCALL_NR_OFFSET, if(ptrace(PTRACE_POKEUSER, pid, PT_SYSCALL_NR_OFFSET,
__NR_getpid) < 0) local_using_sysemu ? -1 : __NR_getpid) < 0)
tracer_panic("do_syscall : Nullifying syscall failed, " tracer_panic("do_syscall : Nullifying syscall failed, "
"errno = %d", errno); "errno = %d", errno);
return(1);
} }
/* /*
......
...@@ -186,7 +186,7 @@ int tracer(int (*init_proc)(void *), void *sp) ...@@ -186,7 +186,7 @@ int tracer(int (*init_proc)(void *), void *sp)
unsigned long eip = 0; unsigned long eip = 0;
int status, pid = 0, sig = 0, cont_type, tracing = 0, op = 0; int status, pid = 0, sig = 0, cont_type, tracing = 0, op = 0;
int last_index, proc_id = 0, n, err, old_tracing = 0, strace = 0; int last_index, proc_id = 0, n, err, old_tracing = 0, strace = 0;
int pt_syscall_parm, local_using_sysemu; int pt_syscall_parm, local_using_sysemu = 0;
signal(SIGPIPE, SIG_IGN); signal(SIGPIPE, SIG_IGN);
setup_tracer_winch(); setup_tracer_winch();
...@@ -307,9 +307,6 @@ int tracer(int (*init_proc)(void *), void *sp) ...@@ -307,9 +307,6 @@ int tracer(int (*init_proc)(void *), void *sp)
if ( tracing ) if ( tracing )
do_sigtrap(task); do_sigtrap(task);
local_using_sysemu = get_using_sysemu();
pt_syscall_parm = local_using_sysemu ? PTRACE_SYSEMU : PTRACE_SYSCALL;
switch(sig){ switch(sig){
case SIGUSR1: case SIGUSR1:
sig = 0; sig = 0;
...@@ -393,6 +390,9 @@ int tracer(int (*init_proc)(void *), void *sp) ...@@ -393,6 +390,9 @@ int tracer(int (*init_proc)(void *), void *sp)
continue; continue;
} }
local_using_sysemu = get_using_sysemu();
pt_syscall_parm = local_using_sysemu ? PTRACE_SYSEMU : PTRACE_SYSCALL;
if(tracing){ if(tracing){
if(singlestepping(task)) if(singlestepping(task))
cont_type = PTRACE_SINGLESTEP; cont_type = PTRACE_SINGLESTEP;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment