proc: get_nr_threads() doesn't need ->siglock any longer
Now that task->signal can't go away get_nr_threads() doesn't need ->siglock to read signal->count. Also, make it inline, move into sched.h, and convert 2 other proc users of signal->count to use this (now trivial) helper. Henceforth get_nr_threads() is the only valid user of signal->count, we are ready to turn it into "int nr_threads" or, perhaps, kill it. Signed-off-by: Oleg Nesterov <oleg@redhat.com> Cc: Alexey Dobriyan <adobriyan@gmail.com> Cc: David Howells <dhowells@redhat.com> Cc: "Eric W. Biederman" <ebiederm@xmission.com> Acked-by: Roland McGrath <roland@redhat.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
Родитель
6e1be45aa6
Коммит
7e49827cc9
|
@ -267,7 +267,7 @@ static inline void task_sig(struct seq_file *m, struct task_struct *p)
|
||||||
shpending = p->signal->shared_pending.signal;
|
shpending = p->signal->shared_pending.signal;
|
||||||
blocked = p->blocked;
|
blocked = p->blocked;
|
||||||
collect_sigign_sigcatch(p, &ignored, &caught);
|
collect_sigign_sigcatch(p, &ignored, &caught);
|
||||||
num_threads = atomic_read(&p->signal->count);
|
num_threads = get_nr_threads(p);
|
||||||
rcu_read_lock(); /* FIXME: is this correct? */
|
rcu_read_lock(); /* FIXME: is this correct? */
|
||||||
qsize = atomic_read(&__task_cred(p)->user->sigpending);
|
qsize = atomic_read(&__task_cred(p)->user->sigpending);
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
|
@ -410,7 +410,7 @@ static int do_task_stat(struct seq_file *m, struct pid_namespace *ns,
|
||||||
tty_nr = new_encode_dev(tty_devnum(sig->tty));
|
tty_nr = new_encode_dev(tty_devnum(sig->tty));
|
||||||
}
|
}
|
||||||
|
|
||||||
num_threads = atomic_read(&sig->count);
|
num_threads = get_nr_threads(task);
|
||||||
collect_sigign_sigcatch(task, &sigign, &sigcatch);
|
collect_sigign_sigcatch(task, &sigign, &sigcatch);
|
||||||
|
|
||||||
cmin_flt = sig->cmin_flt;
|
cmin_flt = sig->cmin_flt;
|
||||||
|
|
|
@ -166,18 +166,6 @@ static int get_fs_path(struct task_struct *task, struct path *path, bool root)
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int get_nr_threads(struct task_struct *tsk)
|
|
||||||
{
|
|
||||||
unsigned long flags;
|
|
||||||
int count = 0;
|
|
||||||
|
|
||||||
if (lock_task_sighand(tsk, &flags)) {
|
|
||||||
count = atomic_read(&tsk->signal->count);
|
|
||||||
unlock_task_sighand(tsk, &flags);
|
|
||||||
}
|
|
||||||
return count;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int proc_cwd_link(struct inode *inode, struct path *path)
|
static int proc_cwd_link(struct inode *inode, struct path *path)
|
||||||
{
|
{
|
||||||
struct task_struct *task = get_proc_task(inode);
|
struct task_struct *task = get_proc_task(inode);
|
||||||
|
|
|
@ -2147,6 +2147,11 @@ extern bool current_is_single_threaded(void);
|
||||||
#define while_each_thread(g, t) \
|
#define while_each_thread(g, t) \
|
||||||
while ((t = next_thread(t)) != g)
|
while ((t = next_thread(t)) != g)
|
||||||
|
|
||||||
|
static inline int get_nr_threads(struct task_struct *tsk)
|
||||||
|
{
|
||||||
|
return atomic_read(&tsk->signal->count);
|
||||||
|
}
|
||||||
|
|
||||||
/* de_thread depends on thread_group_leader not being a pid based check */
|
/* de_thread depends on thread_group_leader not being a pid based check */
|
||||||
#define thread_group_leader(p) (p == p->group_leader)
|
#define thread_group_leader(p) (p == p->group_leader)
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче