Re: [rfc 2/3] fs, proc: Introduce the Children: line in/proc/<pid>/status

From: Andrew Morton
Date: Thu Dec 01 2011 - 16:29:12 EST


On Thu, 1 Dec 2011 13:54:34 +0400
Cyrill Gorcunov <gorcunov@xxxxxxxxx> wrote:

> +int proc_pid_children(struct seq_file *m, struct pid_namespace *ns,
> + struct pid *pid, struct task_struct *task)
> +{
> + struct task_struct *c;
> +
> + read_lock(&tasklist_lock);
> + list_for_each_entry(c, &task->children, sibling)
> + seq_printf(m, " %d", pid_nr_ns(task_pid(c), ns));
> + read_unlock(&tasklist_lock);
> + seq_putc(m, '\n');
> +
> + return 0;
> +}

That's a potentially very long hold time for tasklist_lock, and
userspace can invoke this at a high frequency. Not good.

I think this can all be done under rcu_read_lock() with
list_for_each_entry_rcu().

--
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/