diff options
Diffstat (limited to 'kernel/ptrace.c')
-rw-r--r-- | kernel/ptrace.c | 12 |
1 files changed, 0 insertions, 12 deletions
diff --git a/kernel/ptrace.c b/kernel/ptrace.c index 42ad8ae729a0..6af9cdd558b7 100644 --- a/kernel/ptrace.c +++ b/kernel/ptrace.c | |||
@@ -14,7 +14,6 @@ | |||
14 | #include <linux/mm.h> | 14 | #include <linux/mm.h> |
15 | #include <linux/highmem.h> | 15 | #include <linux/highmem.h> |
16 | #include <linux/pagemap.h> | 16 | #include <linux/pagemap.h> |
17 | #include <linux/smp_lock.h> | ||
18 | #include <linux/ptrace.h> | 17 | #include <linux/ptrace.h> |
19 | #include <linux/security.h> | 18 | #include <linux/security.h> |
20 | #include <linux/signal.h> | 19 | #include <linux/signal.h> |
@@ -76,7 +75,6 @@ void __ptrace_unlink(struct task_struct *child) | |||
76 | child->parent = child->real_parent; | 75 | child->parent = child->real_parent; |
77 | list_del_init(&child->ptrace_entry); | 76 | list_del_init(&child->ptrace_entry); |
78 | 77 | ||
79 | arch_ptrace_untrace(child); | ||
80 | if (task_is_traced(child)) | 78 | if (task_is_traced(child)) |
81 | ptrace_untrace(child); | 79 | ptrace_untrace(child); |
82 | } | 80 | } |
@@ -666,10 +664,6 @@ SYSCALL_DEFINE4(ptrace, long, request, long, pid, long, addr, long, data) | |||
666 | struct task_struct *child; | 664 | struct task_struct *child; |
667 | long ret; | 665 | long ret; |
668 | 666 | ||
669 | /* | ||
670 | * This lock_kernel fixes a subtle race with suid exec | ||
671 | */ | ||
672 | lock_kernel(); | ||
673 | if (request == PTRACE_TRACEME) { | 667 | if (request == PTRACE_TRACEME) { |
674 | ret = ptrace_traceme(); | 668 | ret = ptrace_traceme(); |
675 | if (!ret) | 669 | if (!ret) |
@@ -703,7 +697,6 @@ SYSCALL_DEFINE4(ptrace, long, request, long, pid, long, addr, long, data) | |||
703 | out_put_task_struct: | 697 | out_put_task_struct: |
704 | put_task_struct(child); | 698 | put_task_struct(child); |
705 | out: | 699 | out: |
706 | unlock_kernel(); | ||
707 | return ret; | 700 | return ret; |
708 | } | 701 | } |
709 | 702 | ||
@@ -813,10 +806,6 @@ asmlinkage long compat_sys_ptrace(compat_long_t request, compat_long_t pid, | |||
813 | struct task_struct *child; | 806 | struct task_struct *child; |
814 | long ret; | 807 | long ret; |
815 | 808 | ||
816 | /* | ||
817 | * This lock_kernel fixes a subtle race with suid exec | ||
818 | */ | ||
819 | lock_kernel(); | ||
820 | if (request == PTRACE_TRACEME) { | 809 | if (request == PTRACE_TRACEME) { |
821 | ret = ptrace_traceme(); | 810 | ret = ptrace_traceme(); |
822 | goto out; | 811 | goto out; |
@@ -846,7 +835,6 @@ asmlinkage long compat_sys_ptrace(compat_long_t request, compat_long_t pid, | |||
846 | out_put_task_struct: | 835 | out_put_task_struct: |
847 | put_task_struct(child); | 836 | put_task_struct(child); |
848 | out: | 837 | out: |
849 | unlock_kernel(); | ||
850 | return ret; | 838 | return ret; |
851 | } | 839 | } |
852 | #endif /* CONFIG_COMPAT */ | 840 | #endif /* CONFIG_COMPAT */ |