[RFC PATCH 12/12 v2] ptrace: mv task_struct->ptrace_entryptrace_ctx->entry
From: Oleg Nesterov
Date: Thu May 28 2009 - 07:42:52 EST
Move task_struct->ptrace_entry into ptrace_ctx->entry.
(we can change __ptrace_detach() to have the single ptrace_ctx arg).
include/linux/sched.h | 4 +---
include/linux/init_task.h | 1 -
include/linux/ptrace.h | 4 ++--
kernel/exit.c | 6 +++---
kernel/ptrace.c | 23 +++++++++++++----------
5 files changed, 19 insertions(+), 19 deletions(-)
--- PTRACE/include/linux/sched.h~11_ENTRY 2009-05-28 12:03:26.000000000 +0200
+++ PTRACE/include/linux/sched.h 2009-05-28 12:39:01.000000000 +0200
@@ -1197,11 +1197,9 @@ struct task_struct {
struct ptrace_context *ptrace_ctx;
/*
* ptraced is the list of tasks this task is using ptrace on.
- * This includes both natural children and PTRACE_ATTACH targets.
- * p->ptrace_entry is p's link on the p->parent->ptraced list.
+ * p->ptrace_ctx->entry is p's link on the tracer->ptraced list.
*/
struct list_head ptraced;
- struct list_head ptrace_entry;
#ifdef CONFIG_X86_PTRACE_BTS
/*
--- PTRACE/include/linux/init_task.h~11_ENTRY 2009-05-28 08:41:11.000000000 +0200
+++ PTRACE/include/linux/init_task.h 2009-05-28 12:27:54.000000000 +0200
@@ -137,7 +137,6 @@ extern struct cred init_cred;
.tasks = LIST_HEAD_INIT(tsk.tasks), \
.pushable_tasks = PLIST_NODE_INIT(tsk.pushable_tasks, MAX_PRIO), \
.ptraced = LIST_HEAD_INIT(tsk.ptraced), \
- .ptrace_entry = LIST_HEAD_INIT(tsk.ptrace_entry), \
.real_parent = &tsk, \
.children = LIST_HEAD_INIT(tsk.children), \
.sibling = LIST_HEAD_INIT(tsk.sibling), \
--- PTRACE/include/linux/ptrace.h~11_ENTRY 2009-05-28 12:09:30.000000000 +0200
+++ PTRACE/include/linux/ptrace.h 2009-05-28 12:41:15.000000000 +0200
@@ -80,6 +80,8 @@ struct ptrace_context {
struct task_struct *tracer;
struct siginfo *infop;
unsigned long message;
+ struct task_struct *tracee;
+ struct list_head entry;
};
extern int alloc_ptrace_context(struct task_struct *child);
@@ -176,7 +178,6 @@ static inline int ptrace_event(int mask,
*/
static inline void ptrace_init_task(struct task_struct *child)
{
- INIT_LIST_HEAD(&child->ptrace_entry);
INIT_LIST_HEAD(&child->ptraced);
if (unlikely(child->ptrace_ctx) && ptrace_tracer(current))
@@ -194,7 +195,6 @@ static inline void ptrace_release_task(s
{
BUG_ON(!list_empty(&task->ptraced));
ptrace_unlink(task);
- BUG_ON(!list_empty(&task->ptrace_entry));
}
#ifndef force_successful_syscall_return
--- PTRACE/kernel/exit.c~11_ENTRY 2009-05-28 08:41:11.000000000 +0200
+++ PTRACE/kernel/exit.c 2009-05-28 12:32:07.000000000 +0200
@@ -1545,10 +1545,10 @@ static int do_wait_thread(struct wait_op
static int ptrace_do_wait(struct wait_opts *wo, struct task_struct *tsk)
{
- struct task_struct *p;
+ struct ptrace_context *ctx;
- list_for_each_entry(p, &tsk->ptraced, ptrace_entry) {
- int ret = wait_consider_task(wo, tsk, 1, p);
+ list_for_each_entry(ctx, &tsk->ptraced, entry) {
+ int ret = wait_consider_task(wo, tsk, 1, ctx->tracee);
if (ret)
return ret;
}
--- PTRACE/kernel/ptrace.c~11_ENTRY 2009-05-28 12:11:20.000000000 +0200
+++ PTRACE/kernel/ptrace.c 2009-05-28 12:52:06.000000000 +0200
@@ -45,8 +45,8 @@ void ptrace_link(struct task_struct *chi
{
child->ptrace_ctx->flags = flags | PT_PTRACED;
- BUG_ON(!list_empty(&child->ptrace_entry));
- list_add(&child->ptrace_entry, &tracer->ptraced);
+ BUG_ON(!list_empty(&child->ptrace_ctx->entry));
+ list_add(&child->ptrace_ctx->entry, &tracer->ptraced);
child->ptrace_ctx->tracer = tracer;
}
@@ -86,7 +86,7 @@ void __ptrace_unlink(struct task_struct
child->ptrace_ctx->flags = 0;
child->ptrace_ctx->tracer = NULL;
- list_del_init(&child->ptrace_entry);
+ list_del_init(&child->ptrace_ctx->entry);
arch_ptrace_untrace(child);
if (task_is_traced(child))
@@ -193,6 +193,9 @@ int alloc_ptrace_context(struct task_str
if (unlikely(!ptrace_ctx))
return -ENOMEM;
+ ptrace_ctx->tracee = tsk;
+ INIT_LIST_HEAD(&ptrace_ctx->entry);
+
task_lock(tsk);
if (likely(!tsk->ptrace_ctx))
tsk->ptrace_ctx = ptrace_ctx;
@@ -363,21 +366,21 @@ int ptrace_detach(struct task_struct *ch
*/
void exit_ptrace(struct task_struct *tracer)
{
- struct task_struct *p, *n;
+ struct ptrace_context *ctx, *tmp;
LIST_HEAD(ptrace_dead);
write_lock_irq(&tasklist_lock);
- list_for_each_entry_safe(p, n, &tracer->ptraced, ptrace_entry) {
- if (__ptrace_detach(tracer, p))
- list_add(&p->ptrace_entry, &ptrace_dead);
+ list_for_each_entry_safe(ctx, tmp, &tracer->ptraced, entry) {
+ if (__ptrace_detach(tracer, ctx->tracee))
+ list_add(&ctx->entry, &ptrace_dead);
}
write_unlock_irq(&tasklist_lock);
BUG_ON(!list_empty(&tracer->ptraced));
- list_for_each_entry_safe(p, n, &ptrace_dead, ptrace_entry) {
- list_del_init(&p->ptrace_entry);
- release_task(p);
+ list_for_each_entry_safe(ctx, tmp, &ptrace_dead, entry) {
+ list_del_init(&ctx->entry);
+ release_task(ctx->tracee);
}
}
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/