aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/char/synclink_gt.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/char/synclink_gt.c')
-rw-r--r--drivers/char/synclink_gt.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/drivers/char/synclink_gt.c b/drivers/char/synclink_gt.c
index 6473ae023466..1a11717b1adc 100644
--- a/drivers/char/synclink_gt.c
+++ b/drivers/char/synclink_gt.c
@@ -771,8 +771,7 @@ static void close(struct tty_struct *tty, struct file *filp)
771 771
772 if (info->flags & ASYNC_INITIALIZED) 772 if (info->flags & ASYNC_INITIALIZED)
773 wait_until_sent(tty, info->timeout); 773 wait_until_sent(tty, info->timeout);
774 if (tty->driver->flush_buffer) 774 flush_buffer(tty);
775 tty->driver->flush_buffer(tty);
776 tty_ldisc_flush(tty); 775 tty_ldisc_flush(tty);
777 776
778 shutdown(info); 777 shutdown(info);
@@ -967,6 +966,8 @@ static void wait_until_sent(struct tty_struct *tty, int timeout)
967 * Note: use tight timings here to satisfy the NIST-PCTS. 966 * Note: use tight timings here to satisfy the NIST-PCTS.
968 */ 967 */
969 968
969 lock_kernel();
970
970 if (info->params.data_rate) { 971 if (info->params.data_rate) {
971 char_time = info->timeout/(32 * 5); 972 char_time = info->timeout/(32 * 5);
972 if (!char_time) 973 if (!char_time)
@@ -984,6 +985,7 @@ static void wait_until_sent(struct tty_struct *tty, int timeout)
984 if (timeout && time_after(jiffies, orig_jiffies + timeout)) 985 if (timeout && time_after(jiffies, orig_jiffies + timeout))
985 break; 986 break;
986 } 987 }
988 unlock_kernel();
987 989
988exit: 990exit:
989 DBGINFO(("%s wait_until_sent exit\n", info->device_name)); 991 DBGINFO(("%s wait_until_sent exit\n", info->device_name));