| /* |
| * Copyright (C) 2000, 2001, 2002 Jeff Dike (jdike@karaya.com) |
| * Licensed under the GPL |
| */ |
| |
| #ifndef __PTRACE_USER_H__ |
| #define __PTRACE_USER_H__ |
| |
| #include "sysdep/ptrace_user.h" |
| |
| extern int ptrace_getregs(long pid, unsigned long *regs_out); |
| extern int ptrace_setregs(long pid, unsigned long *regs_in); |
| extern int ptrace_getfpregs(long pid, unsigned long *regs_out); |
| extern int ptrace_setfpregs(long pid, unsigned long *regs); |
| extern void arch_enter_kernel(void *task, int pid); |
| extern void arch_leave_kernel(void *task, int pid); |
| extern void ptrace_pokeuser(unsigned long addr, unsigned long data); |
| |
| |
| /* syscall emulation path in ptrace */ |
| |
| #ifndef PTRACE_SYSEMU |
| #define PTRACE_SYSEMU 31 |
| #endif |
| #ifndef PTRACE_SYSEMU_SINGLESTEP |
| #define PTRACE_SYSEMU_SINGLESTEP 32 |
| #endif |
| |
| /* On architectures, that started to support PTRACE_O_TRACESYSGOOD |
| * in linux 2.4, there are two different definitions of |
| * PTRACE_SETOPTIONS: linux 2.4 uses 21 while linux 2.6 uses 0x4200. |
| * For binary compatibility, 2.6 also supports the old "21", named |
| * PTRACE_OLDSETOPTION. On these architectures, UML always must use |
| * "21", to ensure the kernel runs on 2.4 and 2.6 host without |
| * recompilation. So, we use PTRACE_OLDSETOPTIONS in UML. |
| * We also want to be able to build the kernel on 2.4, which doesn't |
| * have PTRACE_OLDSETOPTIONS. So, if it is missing, we declare |
| * PTRACE_OLDSETOPTIONS to to be the same as PTRACE_SETOPTIONS. |
| * |
| * On architectures, that start to support PTRACE_O_TRACESYSGOOD on |
| * linux 2.6, PTRACE_OLDSETOPTIONS never is defined, and also isn't |
| * supported by the host kernel. In that case, our trick lets us use |
| * the new 0x4200 with the name PTRACE_OLDSETOPTIONS. |
| */ |
| #ifndef PTRACE_OLDSETOPTIONS |
| #define PTRACE_OLDSETOPTIONS PTRACE_SETOPTIONS |
| #endif |
| |
| void set_using_sysemu(int value); |
| int get_using_sysemu(void); |
| extern int sysemu_supported; |
| |
| #define SELECT_PTRACE_OPERATION(sysemu_mode, singlestep_mode) \ |
| (((int[3][3] ) { \ |
| { PTRACE_SYSCALL, PTRACE_SYSCALL, PTRACE_SINGLESTEP }, \ |
| { PTRACE_SYSEMU, PTRACE_SYSEMU, PTRACE_SINGLESTEP }, \ |
| { PTRACE_SYSEMU, PTRACE_SYSEMU_SINGLESTEP, PTRACE_SYSEMU_SINGLESTEP }}) \ |
| [sysemu_mode][singlestep_mode]) |
| |
| #endif |