aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/char
diff options
context:
space:
mode:
authorEric W. Biederman <ebiederm@xmission.com>2007-05-08 03:26:53 -0400
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2007-05-08 14:15:04 -0400
commit2a65f1d9fe78475720bd8f0e0fbbf1973b1b5ac2 (patch)
treef23bfe8a3602d1fea448d3416c639957bccc9677 /drivers/char
parentf67c3627b4abd8a3cf56bd20cafde702feffe236 (diff)
tty: simplify calling of put_pid.
This patch should contain no functional changes. At some point I got confused and thought put_pid could not be called while a spin lock was held. While it may be nice to avoid that to reduce lock hold times put_pid can be safely called while we hold a spin lock. This patch removes all of the complications from the code introduced by my misunderstanding, making the code a little more readable. Signed-off-by: Eric W. Biederman <ebiederm@xmission.com> Cc: Alan Cox <alan@lxorguk.ukuu.org.uk> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/char')
-rw-r--r--drivers/char/tty_io.c23
1 files changed, 6 insertions, 17 deletions
diff --git a/drivers/char/tty_io.c b/drivers/char/tty_io.c
index a7b915516d7b..39db186d5c5b 100644
--- a/drivers/char/tty_io.c
+++ b/drivers/char/tty_io.c
@@ -153,8 +153,7 @@ int tty_ioctl(struct inode * inode, struct file * file,
153 unsigned int cmd, unsigned long arg); 153 unsigned int cmd, unsigned long arg);
154static int tty_fasync(int fd, struct file * filp, int on); 154static int tty_fasync(int fd, struct file * filp, int on);
155static void release_tty(struct tty_struct *tty, int idx); 155static void release_tty(struct tty_struct *tty, int idx);
156static struct pid *__proc_set_tty(struct task_struct *tsk, 156static void __proc_set_tty(struct task_struct *tsk, struct tty_struct *tty);
157 struct tty_struct *tty);
158 157
159/** 158/**
160 * alloc_tty_struct - allocate a tty object 159 * alloc_tty_struct - allocate a tty object
@@ -1532,10 +1531,9 @@ void disassociate_ctty(int on_exit)
1532 } 1531 }
1533 1532
1534 spin_lock_irq(&current->sighand->siglock); 1533 spin_lock_irq(&current->sighand->siglock);
1535 tty_pgrp = current->signal->tty_old_pgrp; 1534 put_pid(current->signal->tty_old_pgrp);
1536 current->signal->tty_old_pgrp = NULL; 1535 current->signal->tty_old_pgrp = NULL;
1537 spin_unlock_irq(&current->sighand->siglock); 1536 spin_unlock_irq(&current->sighand->siglock);
1538 put_pid(tty_pgrp);
1539 1537
1540 mutex_lock(&tty_mutex); 1538 mutex_lock(&tty_mutex);
1541 /* It is possible that do_tty_hangup has free'd this tty */ 1539 /* It is possible that do_tty_hangup has free'd this tty */
@@ -2506,7 +2504,6 @@ static int tty_open(struct inode * inode, struct file * filp)
2506 int index; 2504 int index;
2507 dev_t device = inode->i_rdev; 2505 dev_t device = inode->i_rdev;
2508 unsigned short saved_flags = filp->f_flags; 2506 unsigned short saved_flags = filp->f_flags;
2509 struct pid *old_pgrp;
2510 2507
2511 nonseekable_open(inode, filp); 2508 nonseekable_open(inode, filp);
2512 2509
@@ -2600,17 +2597,15 @@ got_driver:
2600 goto retry_open; 2597 goto retry_open;
2601 } 2598 }
2602 2599
2603 old_pgrp = NULL;
2604 mutex_lock(&tty_mutex); 2600 mutex_lock(&tty_mutex);
2605 spin_lock_irq(&current->sighand->siglock); 2601 spin_lock_irq(&current->sighand->siglock);
2606 if (!noctty && 2602 if (!noctty &&
2607 current->signal->leader && 2603 current->signal->leader &&
2608 !current->signal->tty && 2604 !current->signal->tty &&
2609 tty->session == NULL) 2605 tty->session == NULL)
2610 old_pgrp = __proc_set_tty(current, tty); 2606 __proc_set_tty(current, tty);
2611 spin_unlock_irq(&current->sighand->siglock); 2607 spin_unlock_irq(&current->sighand->siglock);
2612 mutex_unlock(&tty_mutex); 2608 mutex_unlock(&tty_mutex);
2613 put_pid(old_pgrp);
2614 return 0; 2609 return 0;
2615} 2610}
2616 2611
@@ -3835,9 +3830,8 @@ void proc_clear_tty(struct task_struct *p)
3835 spin_unlock_irq(&p->sighand->siglock); 3830 spin_unlock_irq(&p->sighand->siglock);
3836} 3831}
3837 3832
3838static struct pid *__proc_set_tty(struct task_struct *tsk, struct tty_struct *tty) 3833static void __proc_set_tty(struct task_struct *tsk, struct tty_struct *tty)
3839{ 3834{
3840 struct pid *old_pgrp;
3841 if (tty) { 3835 if (tty) {
3842 /* We should not have a session or pgrp to here but.... */ 3836 /* We should not have a session or pgrp to here but.... */
3843 put_pid(tty->session); 3837 put_pid(tty->session);
@@ -3845,21 +3839,16 @@ static struct pid *__proc_set_tty(struct task_struct *tsk, struct tty_struct *tt
3845 tty->session = get_pid(task_session(tsk)); 3839 tty->session = get_pid(task_session(tsk));
3846 tty->pgrp = get_pid(task_pgrp(tsk)); 3840 tty->pgrp = get_pid(task_pgrp(tsk));
3847 } 3841 }
3848 old_pgrp = tsk->signal->tty_old_pgrp; 3842 put_pid(tsk->signal->tty_old_pgrp);
3849 tsk->signal->tty = tty; 3843 tsk->signal->tty = tty;
3850 tsk->signal->tty_old_pgrp = NULL; 3844 tsk->signal->tty_old_pgrp = NULL;
3851 return old_pgrp;
3852} 3845}
3853 3846
3854void proc_set_tty(struct task_struct *tsk, struct tty_struct *tty) 3847void proc_set_tty(struct task_struct *tsk, struct tty_struct *tty)
3855{ 3848{
3856 struct pid *old_pgrp;
3857
3858 spin_lock_irq(&tsk->sighand->siglock); 3849 spin_lock_irq(&tsk->sighand->siglock);
3859 old_pgrp = __proc_set_tty(tsk, tty); 3850 __proc_set_tty(tsk, tty);
3860 spin_unlock_irq(&tsk->sighand->siglock); 3851 spin_unlock_irq(&tsk->sighand->siglock);
3861
3862 put_pid(old_pgrp);
3863} 3852}
3864 3853
3865struct tty_struct *get_current_tty(void) 3854struct tty_struct *get_current_tty(void)