aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/char
diff options
context:
space:
mode:
authorAlan Cox <alan@linux.intel.com>2009-11-30 08:18:40 -0500
committerGreg Kroah-Hartman <gregkh@suse.de>2009-12-11 18:18:08 -0500
commit38c70b27f9502c31c1d0c29676275f7362cdb0d9 (patch)
treef7545467d3c060a9df2940f731524b74d2f8c2dd /drivers/char
parentf18f9498e90327b9b0e245e191029e6e1996d203 (diff)
tty: Push the bkl down a bit in the hangup code
We know that the redirect field is handled via its own locking in all places Signed-off-by: Alan Cox <alan@linux.intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/char')
-rw-r--r--drivers/char/tty_io.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/char/tty_io.c b/drivers/char/tty_io.c
index c408c81c06a0..cc941a3504d7 100644
--- a/drivers/char/tty_io.c
+++ b/drivers/char/tty_io.c
@@ -505,8 +505,6 @@ static void do_tty_hangup(struct work_struct *work)
505 if (!tty) 505 if (!tty)
506 return; 506 return;
507 507
508 /* inuse_filps is protected by the single kernel lock */
509 lock_kernel();
510 508
511 spin_lock(&redirect_lock); 509 spin_lock(&redirect_lock);
512 if (redirect && redirect->private_data == tty) { 510 if (redirect && redirect->private_data == tty) {
@@ -515,6 +513,8 @@ static void do_tty_hangup(struct work_struct *work)
515 } 513 }
516 spin_unlock(&redirect_lock); 514 spin_unlock(&redirect_lock);
517 515
516 /* inuse_filps is protected by the single kernel lock */
517 lock_kernel();
518 check_tty_count(tty, "do_tty_hangup"); 518 check_tty_count(tty, "do_tty_hangup");
519 file_list_lock(); 519 file_list_lock();
520 /* This breaks for file handles being sent over AF_UNIX sockets ? */ 520 /* This breaks for file handles being sent over AF_UNIX sockets ? */