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 /include | |
| 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 'include')
| -rw-r--r-- | include/linux/sched.h | 1 | ||||
| -rw-r--r-- | include/linux/taskstats_kern.h | 15 |
2 files changed, 6 insertions, 10 deletions
diff --git a/include/linux/sched.h b/include/linux/sched.h index 6735c1cf334c..eafe4a7b8237 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h | |||
| @@ -466,7 +466,6 @@ struct signal_struct { | |||
| 466 | struct pacct_struct pacct; /* per-process accounting information */ | 466 | struct pacct_struct pacct; /* per-process accounting information */ |
| 467 | #endif | 467 | #endif |
| 468 | #ifdef CONFIG_TASKSTATS | 468 | #ifdef CONFIG_TASKSTATS |
| 469 | spinlock_t stats_lock; | ||
| 470 | struct taskstats *stats; | 469 | struct taskstats *stats; |
| 471 | #endif | 470 | #endif |
| 472 | }; | 471 | }; |
diff --git a/include/linux/taskstats_kern.h b/include/linux/taskstats_kern.h index 664224008fb2..6562a2050a25 100644 --- a/include/linux/taskstats_kern.h +++ b/include/linux/taskstats_kern.h | |||
| @@ -23,28 +23,26 @@ static inline void taskstats_exit_free(struct taskstats *tidstats) | |||
| 23 | 23 | ||
| 24 | static inline void taskstats_tgid_init(struct signal_struct *sig) | 24 | static inline void taskstats_tgid_init(struct signal_struct *sig) |
| 25 | { | 25 | { |
| 26 | spin_lock_init(&sig->stats_lock); | ||
| 27 | sig->stats = NULL; | 26 | sig->stats = NULL; |
| 28 | } | 27 | } |
| 29 | 28 | ||
| 30 | static inline void taskstats_tgid_alloc(struct signal_struct *sig) | 29 | static inline void taskstats_tgid_alloc(struct task_struct *tsk) |
| 31 | { | 30 | { |
| 31 | struct signal_struct *sig = tsk->signal; | ||
| 32 | struct taskstats *stats; | 32 | struct taskstats *stats; |
| 33 | unsigned long flags; | ||
| 34 | 33 | ||
| 35 | if (sig->stats != NULL) | 34 | if (sig->stats != NULL) |
| 36 | return; | 35 | return; |
| 37 | 36 | ||
| 37 | /* No problem if kmem_cache_zalloc() fails */ | ||
| 38 | stats = kmem_cache_zalloc(taskstats_cache, SLAB_KERNEL); | 38 | stats = kmem_cache_zalloc(taskstats_cache, SLAB_KERNEL); |
| 39 | if (!stats) | ||
| 40 | return; | ||
| 41 | 39 | ||
| 42 | spin_lock_irqsave(&sig->stats_lock, flags); | 40 | spin_lock_irq(&tsk->sighand->siglock); |
| 43 | if (!sig->stats) { | 41 | if (!sig->stats) { |
| 44 | sig->stats = stats; | 42 | sig->stats = stats; |
| 45 | stats = NULL; | 43 | stats = NULL; |
| 46 | } | 44 | } |
| 47 | spin_unlock_irqrestore(&sig->stats_lock, flags); | 45 | spin_unlock_irq(&tsk->sighand->siglock); |
| 48 | 46 | ||
| 49 | if (stats) | 47 | if (stats) |
| 50 | kmem_cache_free(taskstats_cache, stats); | 48 | kmem_cache_free(taskstats_cache, stats); |
| @@ -59,7 +57,6 @@ static inline void taskstats_tgid_free(struct signal_struct *sig) | |||
| 59 | extern void taskstats_exit_alloc(struct taskstats **, unsigned int *); | 57 | extern void taskstats_exit_alloc(struct taskstats **, unsigned int *); |
| 60 | extern void taskstats_exit_send(struct task_struct *, struct taskstats *, int, unsigned int); | 58 | extern void taskstats_exit_send(struct task_struct *, struct taskstats *, int, unsigned int); |
| 61 | extern void taskstats_init_early(void); | 59 | extern void taskstats_init_early(void); |
| 62 | extern void taskstats_tgid_alloc(struct signal_struct *); | ||
| 63 | #else | 60 | #else |
| 64 | static inline void taskstats_exit_alloc(struct taskstats **ptidstats, unsigned int *mycpu) | 61 | static inline void taskstats_exit_alloc(struct taskstats **ptidstats, unsigned int *mycpu) |
| 65 | {} | 62 | {} |
| @@ -71,7 +68,7 @@ static inline void taskstats_exit_send(struct task_struct *tsk, | |||
| 71 | {} | 68 | {} |
| 72 | static inline void taskstats_tgid_init(struct signal_struct *sig) | 69 | static inline void taskstats_tgid_init(struct signal_struct *sig) |
| 73 | {} | 70 | {} |
| 74 | static inline void taskstats_tgid_alloc(struct signal_struct *sig) | 71 | static inline void taskstats_tgid_alloc(struct task_struct *tsk) |
| 75 | {} | 72 | {} |
| 76 | static inline void taskstats_tgid_free(struct signal_struct *sig) | 73 | static inline void taskstats_tgid_free(struct signal_struct *sig) |
| 77 | {} | 74 | {} |
