diff options
author | Oleg Nesterov <oleg@tv-sign.ru> | 2006-10-28 13:38:53 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-10-28 14:30:54 -0400 |
commit | b8534d7bd89df0cd41cd47bcd6733a05ea9a691a (patch) | |
tree | c4650f417d7f05a9c645d6a0b1f64405ec4c8a39 /kernel | |
parent | 17b02695b254aa2ef0e53df9c8e6548f86e66a9d (diff) |
[PATCH] taskstats: kill ->taskstats_lock in favor of ->siglock
signal_struct is (mostly) protected by ->sighand->siglock, I think we don't
need ->taskstats_lock to protect ->stats. This also allows us to simplify the
locking in fill_tgid().
Signed-off-by: Oleg Nesterov <oleg@tv-sign.ru>
Cc: Shailabh Nagar <nagar@watson.ibm.com>
Cc: Balbir Singh <balbir@in.ibm.com>
Cc: Jay Lan <jlan@sgi.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/fork.c | 2 | ||||
-rw-r--r-- | kernel/taskstats.c | 16 |
2 files changed, 7 insertions, 11 deletions
diff --git a/kernel/fork.c b/kernel/fork.c index 213326609bac..3da978eec791 100644 --- a/kernel/fork.c +++ b/kernel/fork.c | |||
@@ -830,7 +830,7 @@ static inline int copy_signal(unsigned long clone_flags, struct task_struct * ts | |||
830 | if (clone_flags & CLONE_THREAD) { | 830 | if (clone_flags & CLONE_THREAD) { |
831 | atomic_inc(¤t->signal->count); | 831 | atomic_inc(¤t->signal->count); |
832 | atomic_inc(¤t->signal->live); | 832 | atomic_inc(¤t->signal->live); |
833 | taskstats_tgid_alloc(current->signal); | 833 | taskstats_tgid_alloc(current); |
834 | return 0; | 834 | return 0; |
835 | } | 835 | } |
836 | sig = kmem_cache_alloc(signal_cachep, GFP_KERNEL); | 836 | sig = kmem_cache_alloc(signal_cachep, GFP_KERNEL); |
diff --git a/kernel/taskstats.c b/kernel/taskstats.c index 9aeee511a463..b2efda94615a 100644 --- a/kernel/taskstats.c +++ b/kernel/taskstats.c | |||
@@ -241,11 +241,11 @@ static int fill_tgid(pid_t tgid, struct task_struct *tgidtsk, | |||
241 | tsk = first; | 241 | tsk = first; |
242 | read_lock(&tasklist_lock); | 242 | read_lock(&tasklist_lock); |
243 | /* Start with stats from dead tasks */ | 243 | /* Start with stats from dead tasks */ |
244 | if (first->signal) { | 244 | if (first->sighand) { |
245 | spin_lock_irqsave(&first->signal->stats_lock, flags); | 245 | spin_lock_irqsave(&first->sighand->siglock, flags); |
246 | if (first->signal->stats) | 246 | if (first->signal->stats) |
247 | memcpy(stats, first->signal->stats, sizeof(*stats)); | 247 | memcpy(stats, first->signal->stats, sizeof(*stats)); |
248 | spin_unlock_irqrestore(&first->signal->stats_lock, flags); | 248 | spin_unlock_irqrestore(&first->sighand->siglock, flags); |
249 | } | 249 | } |
250 | 250 | ||
251 | do { | 251 | do { |
@@ -276,7 +276,7 @@ static void fill_tgid_exit(struct task_struct *tsk) | |||
276 | { | 276 | { |
277 | unsigned long flags; | 277 | unsigned long flags; |
278 | 278 | ||
279 | spin_lock_irqsave(&tsk->signal->stats_lock, flags); | 279 | spin_lock_irqsave(&tsk->sighand->siglock, flags); |
280 | if (!tsk->signal->stats) | 280 | if (!tsk->signal->stats) |
281 | goto ret; | 281 | goto ret; |
282 | 282 | ||
@@ -288,7 +288,7 @@ static void fill_tgid_exit(struct task_struct *tsk) | |||
288 | */ | 288 | */ |
289 | delayacct_add_tsk(tsk->signal->stats, tsk); | 289 | delayacct_add_tsk(tsk->signal->stats, tsk); |
290 | ret: | 290 | ret: |
291 | spin_unlock_irqrestore(&tsk->signal->stats_lock, flags); | 291 | spin_unlock_irqrestore(&tsk->sighand->siglock, flags); |
292 | return; | 292 | return; |
293 | } | 293 | } |
294 | 294 | ||
@@ -464,15 +464,10 @@ void taskstats_exit_send(struct task_struct *tsk, struct taskstats *tidstats, | |||
464 | size_t size; | 464 | size_t size; |
465 | int is_thread_group; | 465 | int is_thread_group; |
466 | struct nlattr *na; | 466 | struct nlattr *na; |
467 | unsigned long flags; | ||
468 | 467 | ||
469 | if (!family_registered || !tidstats) | 468 | if (!family_registered || !tidstats) |
470 | return; | 469 | return; |
471 | 470 | ||
472 | spin_lock_irqsave(&tsk->signal->stats_lock, flags); | ||
473 | is_thread_group = tsk->signal->stats ? 1 : 0; | ||
474 | spin_unlock_irqrestore(&tsk->signal->stats_lock, flags); | ||
475 | |||
476 | rc = 0; | 471 | rc = 0; |
477 | /* | 472 | /* |
478 | * Size includes space for nested attributes | 473 | * Size includes space for nested attributes |
@@ -480,6 +475,7 @@ void taskstats_exit_send(struct task_struct *tsk, struct taskstats *tidstats, | |||
480 | size = nla_total_size(sizeof(u32)) + | 475 | size = nla_total_size(sizeof(u32)) + |
481 | nla_total_size(sizeof(struct taskstats)) + nla_total_size(0); | 476 | nla_total_size(sizeof(struct taskstats)) + nla_total_size(0); |
482 | 477 | ||
478 | is_thread_group = (tsk->signal->stats != NULL); | ||
483 | if (is_thread_group) | 479 | if (is_thread_group) |
484 | size = 2 * size; /* PID + STATS + TGID + STATS */ | 480 | size = 2 * size; /* PID + STATS + TGID + STATS */ |
485 | 481 | ||