diff options
| author | Frederic Weisbecker <fweisbec@gmail.com> | 2013-05-02 17:37:49 +0200 | 
|---|---|---|
| committer | Frederic Weisbecker <fweisbec@gmail.com> | 2013-05-02 17:54:19 +0200 | 
| commit | c032862fba51a3ca504752d3a25186b324c5ce83 (patch) | |
| tree | 955dc2ba4ab3df76ecc2bb780ee84aca04967e8d /drivers/tty/tty_buffer.c | |
| parent | fda76e074c7737fc57855dd17c762e50ed526052 (diff) | |
| parent | 8700c95adb033843fc163d112b9d21d4fda78018 (diff) | |
| download | olio-linux-3.10-c032862fba51a3ca504752d3a25186b324c5ce83.tar.xz olio-linux-3.10-c032862fba51a3ca504752d3a25186b324c5ce83.zip  | |
Merge commit '8700c95adb03' into timers/nohz
The full dynticks tree needs the latest RCU and sched
upstream updates in order to fix some dependencies.
Merge a common upstream merge point that has these
updates.
Conflicts:
	include/linux/perf_event.h
	kernel/rcutree.h
	kernel/rcutree_plugin.h
Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com>
Diffstat (limited to 'drivers/tty/tty_buffer.c')
| -rw-r--r-- | drivers/tty/tty_buffer.c | 24 | 
1 files changed, 11 insertions, 13 deletions
diff --git a/drivers/tty/tty_buffer.c b/drivers/tty/tty_buffer.c index bb119934e76..9121c1f7aee 100644 --- a/drivers/tty/tty_buffer.c +++ b/drivers/tty/tty_buffer.c @@ -425,7 +425,7 @@ static void flush_to_ldisc(struct work_struct *work)  	struct tty_ldisc *disc;  	tty = port->itty; -	if (WARN_RATELIMIT(tty == NULL, "tty is NULL\n")) +	if (tty == NULL)  		return;  	disc = tty_ldisc_ref(tty); @@ -449,11 +449,6 @@ static void flush_to_ldisc(struct work_struct *work)  				tty_buffer_free(port, head);  				continue;  			} -			/* Ldisc or user is trying to flush the buffers -			   we are feeding to the ldisc, stop feeding the -			   line discipline as we want to empty the queue */ -			if (test_bit(TTYP_FLUSHPENDING, &port->iflags)) -				break;  			if (!tty->receive_room)  				break;  			if (count > tty->receive_room) @@ -465,17 +460,20 @@ static void flush_to_ldisc(struct work_struct *work)  			disc->ops->receive_buf(tty, char_buf,  							flag_buf, count);  			spin_lock_irqsave(&buf->lock, flags); +			/* Ldisc or user is trying to flush the buffers. +			   We may have a deferred request to flush the +			   input buffer, if so pull the chain under the lock +			   and empty the queue */ +			if (test_bit(TTYP_FLUSHPENDING, &port->iflags)) { +				__tty_buffer_flush(port); +				clear_bit(TTYP_FLUSHPENDING, &port->iflags); +				wake_up(&tty->read_wait); +				break; +			}  		}  		clear_bit(TTYP_FLUSHING, &port->iflags);  	} -	/* We may have a deferred request to flush the input buffer, -	   if so pull the chain under the lock and empty the queue */ -	if (test_bit(TTYP_FLUSHPENDING, &port->iflags)) { -		__tty_buffer_flush(port); -		clear_bit(TTYP_FLUSHPENDING, &port->iflags); -		wake_up(&tty->read_wait); -	}  	spin_unlock_irqrestore(&buf->lock, flags);  	tty_ldisc_deref(disc);  |