|
@@ -1207,68 +1207,15 @@ static int genregs32_set(struct task_struct *target,
|
|
|
return ret;
|
|
|
}
|
|
|
|
|
|
-asmlinkage long sys32_ptrace(long request, u32 pid, u32 addr, u32 data)
|
|
|
+long compat_arch_ptrace(struct task_struct *child, compat_long_t request,
|
|
|
+ compat_ulong_t caddr, compat_ulong_t cdata)
|
|
|
{
|
|
|
- struct task_struct *child;
|
|
|
- struct pt_regs *childregs;
|
|
|
+ unsigned long addr = caddr;
|
|
|
+ unsigned long data = cdata;
|
|
|
void __user *datap = compat_ptr(data);
|
|
|
int ret;
|
|
|
__u32 val;
|
|
|
|
|
|
- switch (request) {
|
|
|
- case PTRACE_TRACEME:
|
|
|
- case PTRACE_ATTACH:
|
|
|
- case PTRACE_KILL:
|
|
|
- case PTRACE_CONT:
|
|
|
- case PTRACE_SINGLESTEP:
|
|
|
- case PTRACE_SINGLEBLOCK:
|
|
|
- case PTRACE_DETACH:
|
|
|
- case PTRACE_SYSCALL:
|
|
|
- case PTRACE_OLDSETOPTIONS:
|
|
|
- case PTRACE_SETOPTIONS:
|
|
|
- case PTRACE_SET_THREAD_AREA:
|
|
|
- case PTRACE_GET_THREAD_AREA:
|
|
|
-#ifdef X86_BTS
|
|
|
- case PTRACE_BTS_CONFIG:
|
|
|
- case PTRACE_BTS_STATUS:
|
|
|
- case PTRACE_BTS_SIZE:
|
|
|
- case PTRACE_BTS_GET:
|
|
|
- case PTRACE_BTS_CLEAR:
|
|
|
- case PTRACE_BTS_DRAIN:
|
|
|
-#endif
|
|
|
- return sys_ptrace(request, pid, addr, data);
|
|
|
-
|
|
|
- default:
|
|
|
- return -EINVAL;
|
|
|
-
|
|
|
- case PTRACE_PEEKTEXT:
|
|
|
- case PTRACE_PEEKDATA:
|
|
|
- case PTRACE_POKEDATA:
|
|
|
- case PTRACE_POKETEXT:
|
|
|
- case PTRACE_POKEUSR:
|
|
|
- case PTRACE_PEEKUSR:
|
|
|
- case PTRACE_GETREGS:
|
|
|
- case PTRACE_SETREGS:
|
|
|
- case PTRACE_SETFPREGS:
|
|
|
- case PTRACE_GETFPREGS:
|
|
|
- case PTRACE_SETFPXREGS:
|
|
|
- case PTRACE_GETFPXREGS:
|
|
|
- case PTRACE_GETEVENTMSG:
|
|
|
- case PTRACE_SETSIGINFO:
|
|
|
- case PTRACE_GETSIGINFO:
|
|
|
- break;
|
|
|
- }
|
|
|
-
|
|
|
- child = ptrace_get_task_struct(pid);
|
|
|
- if (IS_ERR(child))
|
|
|
- return PTR_ERR(child);
|
|
|
-
|
|
|
- ret = ptrace_check_attach(child, request == PTRACE_KILL);
|
|
|
- if (ret < 0)
|
|
|
- goto out;
|
|
|
-
|
|
|
- childregs = task_pt_regs(child);
|
|
|
-
|
|
|
switch (request) {
|
|
|
case PTRACE_PEEKUSR:
|
|
|
ret = getreg32(child, addr, &val);
|
|
@@ -1315,12 +1262,14 @@ asmlinkage long sys32_ptrace(long request, u32 pid, u32 addr, u32 data)
|
|
|
sizeof(struct user32_fxsr_struct),
|
|
|
datap);
|
|
|
|
|
|
+ case PTRACE_GET_THREAD_AREA:
|
|
|
+ case PTRACE_SET_THREAD_AREA:
|
|
|
+ return arch_ptrace(child, request, addr, data);
|
|
|
+
|
|
|
default:
|
|
|
return compat_ptrace_request(child, request, addr, data);
|
|
|
}
|
|
|
|
|
|
- out:
|
|
|
- put_task_struct(child);
|
|
|
return ret;
|
|
|
}
|
|
|
|