summaryrefslogtreecommitdiff
path: root/drivers/net/irda
diff options
context:
space:
mode:
authorPeter Hurley <peter@hurleysoftware.com>2014-11-05 17:12:51 (GMT)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2014-11-06 02:24:10 (GMT)
commitaa3cb814a8efae1b7c81516b4bee41f831fe2e7a (patch)
tree605a0b8caa6509226aa78900666f4aea4867f9a8 /drivers/net/irda
parent52494eeb993ef6865f7817c8b473f798771371fc (diff)
downloadlinux-aa3cb814a8efae1b7c81516b4bee41f831fe2e7a.tar.xz
tty: Drop tty_mutex before tty reopen
Holding tty_mutex for a tty re-open is no longer necessary since "tty: Clarify re-open behavior of master ptys". Because the slave tty count is no longer accessed by tty_reopen(), holding tty_mutex to prevent concurrent final tty_release() of the slave pty is not required. As with "tty: Re-open /dev/tty without tty_mutex", holding a tty kref until the tty_lock is acquired is sufficient to ensure the tty has not been freed, which, in turn, is sufficient to ensure the tty_lock can be safely acquired and the tty count can be safely retrieved. A non-zero tty count with the tty lock held guarantees that release_tty() has not run and cannot run concurrently with tty_reopen(). Change tty_driver_lookup_tty() to acquire the tty kref, which allows the tty_mutex to be dropped before acquiring the tty lock. Dropping the tty_mutex before attempting the tty_lock allows other ttys to be opened and released, without needing this tty_reopen() to complete. Reviewed-by: Alan Cox <alan@linux.intel.com> Signed-off-by: Peter Hurley <peter@hurleysoftware.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/net/irda')
0 files changed, 0 insertions, 0 deletions