diff options
author | Peter Hurley <peter@hurleysoftware.com> | 2014-10-16 14:59:47 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2014-11-05 16:26:13 -0800 |
commit | 2c411c11020ff356748268ca9cae4c1b4c410f00 (patch) | |
tree | 77364bc6b8920b9a644416d2e5327f63ad232382 /include/linux/rio_ids.h | |
parent | ae28fa721683f29105d6894c6c1482bf5a470d3b (diff) | |
download | talos-op-linux-2c411c11020ff356748268ca9cae4c1b4c410f00.tar.gz talos-op-linux-2c411c11020ff356748268ca9cae4c1b4c410f00.zip |
tty: Fix multiple races when setting the controlling terminal
Claim a read lock on the tasklist_lock while setting the controlling
terminal for the session leader. This fixes multiple races:
1. task_pgrp() and task_session() cannot be safely dereferenced, such
as passing to get_pid(), without holding either rcu_read_lock() or
tasklist_lock
2. setsid() unwisely allows any thread in the thread group to
make the thread group leader the session leader; this makes the
unlocked reads of ->signal->leader and signal->tty potentially
unordered, stale or even have spurious values.
Signed-off-by: Peter Hurley <peter@hurleysoftware.com>
Reviewed-by: Alan Cox <alan@linux.intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'include/linux/rio_ids.h')
0 files changed, 0 insertions, 0 deletions