aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric W. Biederman <ebiederm@xmission.com>2006-10-02 05:17:09 -0400
committerLinus Torvalds <torvalds@g5.osdl.org>2006-10-02 10:57:13 -0400
commit558cb325485aaf655130f140e8ddd25392f6c972 (patch)
treeadfea6c0b901cf6591209d29091ff5ac298843c3
parent22c935f47c03399c78e64c71b757eb36fa917ff6 (diff)
[PATCH] pid: add do_each_pid_task
To avoid pid rollover confusion the kernel needs to work with struct pid * instead of pid_t. Currently there is not an iterator that walks through all of the tasks of a given pid type starting with a struct pid. This prevents us replacing some pid_t instances with struct pid. So this patch adds do_each_pid_task which walks through the set of task for a given pid type starting with a struct pid. Signed-off-by: Eric W. Biederman <ebiederm@xmission.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
-rw-r--r--include/linux/pid.h13
1 files changed, 13 insertions, 0 deletions
diff --git a/include/linux/pid.h b/include/linux/pid.h
index 359121086de..8cf9b11ed26 100644
--- a/include/linux/pid.h
+++ b/include/linux/pid.h
@@ -119,4 +119,17 @@ extern void FASTCALL(free_pid(struct pid *pid));
119 1; }) ); \ 119 1; }) ); \
120 } 120 }
121 121
122#define do_each_pid_task(pid, type, task) \
123 if ((task = pid_task(pid, type))) { \
124 prefetch(pid_next(task, type)); \
125 do {
126
127#define while_each_pid_task(pid, type, task) \
128 } while (pid_next(task, type) && ({ \
129 task = pid_next_task(task, type); \
130 rcu_dereference(task); \
131 prefetch(pid_next(task, type)); \
132 1; }) ); \
133 }
134
122#endif /* _LINUX_PID_H */ 135#endif /* _LINUX_PID_H */