Merge branch 'locking-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel...
[jlayton/linux.git] / drivers / tty / n_tty.c
index 746ae80b972f4f40bad5099f6f74770ec70b995e..f95569dedc88b4b60a07428bfe70069b22f561e6 100644 (file)
@@ -2353,8 +2353,12 @@ static ssize_t n_tty_write(struct tty_struct *tty, struct file *file,
                        if (tty->ops->flush_chars)
                                tty->ops->flush_chars(tty);
                } else {
+                       struct n_tty_data *ldata = tty->disc_data;
+
                        while (nr > 0) {
+                               mutex_lock(&ldata->output_lock);
                                c = tty->ops->write(tty, b, nr);
+                               mutex_unlock(&ldata->output_lock);
                                if (c < 0) {
                                        retval = c;
                                        goto break_out;