]> pilppa.com Git - linux-2.6-omap-h63xx.git/commitdiff
[POWERPC] Use generic compat_sys_ptrace
authorRoland McGrath <roland@redhat.com>
Thu, 20 Dec 2007 11:58:55 +0000 (03:58 -0800)
committerPaul Mackerras <paulus@samba.org>
Thu, 7 Feb 2008 09:40:21 +0000 (20:40 +1100)
This replaces powerpc's compat_sys_ptrace with a compat_arch_ptrace and
enables the new generic definition of compat_sys_ptrace instead.

Signed-off-by: Roland McGrath <roland@redhat.com>
Signed-off-by: Paul Mackerras <paulus@samba.org>
arch/powerpc/kernel/ptrace32.c
include/asm-powerpc/ptrace.h

index 6612304e11e3a43da1aa2aff5f266d8a01dbcdcb..0f6eea086a2372205ea53b9842fb734e1eb85896 100644 (file)
@@ -85,33 +85,13 @@ static long compat_ptrace_old(struct task_struct *child, long request,
        return ret;
 }
 
-long compat_sys_ptrace(int request, int pid, unsigned long addr,
-                      unsigned long 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;
+       unsigned long addr = caddr;
+       unsigned long data = cdata;
        int ret;
 
-       lock_kernel();
-       if (request == PTRACE_TRACEME) {
-               ret = ptrace_traceme();
-               goto out;
-       }
-
-       child = ptrace_get_task_struct(pid);
-       if (IS_ERR(child)) {
-               ret = PTR_ERR(child);
-               goto out;
-       }
-
-       if (request == PTRACE_ATTACH) {
-               ret = ptrace_attach(child);
-               goto out_tsk;
-       }
-
-       ret = ptrace_check_attach(child, request == PTRACE_KILL);
-       if (ret < 0)
-               goto out_tsk;
-
        switch (request) {
        /*
         * Read 4 bytes of the other process' storage
@@ -375,9 +355,6 @@ long compat_sys_ptrace(int request, int pid, unsigned long addr,
                ret = compat_ptrace_request(child, request, addr, data);
                break;
        }
-out_tsk:
-       put_task_struct(child);
-out:
-       unlock_kernel();
+
        return ret;
 }
index ffc150f602b81d5a6c55ea9f4b97d00ef5a0550e..891d68932f39975143b7dcc42fe4e0fbf96a414a 100644 (file)
@@ -55,6 +55,8 @@ struct pt_regs {
 
 #ifdef __powerpc64__
 
+#define __ARCH_WANT_COMPAT_SYS_PTRACE
+
 #define STACK_FRAME_OVERHEAD   112     /* size of minimum stack frame */
 
 /* Size of dummy stack frame allocated when calling signal handler. */