forked from mirrors/linux
		
	SERIAL: core: add hardware assisted h/w flow control support
Ports which are handling h/w flow control in hardware must not have their RTS state altered depending on the tty's hardware-stopped state. Avoid this additional logic when setting the termios state. Acked-by: Alan Cox <alan@linux.intel.com> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
This commit is contained in:
		
							parent
							
								
									2cbacafd7a
								
							
						
					
					
						commit
						dba05832cb
					
				
					 2 changed files with 9 additions and 0 deletions
				
			
		| 
						 | 
					@ -1255,6 +1255,13 @@ static void uart_set_termios(struct tty_struct *tty,
 | 
				
			||||||
		uart_set_mctrl(uport, mask);
 | 
							uart_set_mctrl(uport, mask);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/*
 | 
				
			||||||
 | 
						 * If the port is doing h/w assisted flow control, do nothing.
 | 
				
			||||||
 | 
						 * We assume that tty->hw_stopped has never been set.
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
						if (uport->flags & UPF_HARD_FLOW)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Handle turning off CRTSCTS */
 | 
						/* Handle turning off CRTSCTS */
 | 
				
			||||||
	if ((old_termios->c_cflag & CRTSCTS) && !(cflag & CRTSCTS)) {
 | 
						if ((old_termios->c_cflag & CRTSCTS) && !(cflag & CRTSCTS)) {
 | 
				
			||||||
		spin_lock_irqsave(&uport->lock, flags);
 | 
							spin_lock_irqsave(&uport->lock, flags);
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -163,6 +163,8 @@ struct uart_port {
 | 
				
			||||||
#define UPF_BUGGY_UART		((__force upf_t) (1 << 14))
 | 
					#define UPF_BUGGY_UART		((__force upf_t) (1 << 14))
 | 
				
			||||||
#define UPF_NO_TXEN_TEST	((__force upf_t) (1 << 15))
 | 
					#define UPF_NO_TXEN_TEST	((__force upf_t) (1 << 15))
 | 
				
			||||||
#define UPF_MAGIC_MULTIPLIER	((__force upf_t) (1 << 16))
 | 
					#define UPF_MAGIC_MULTIPLIER	((__force upf_t) (1 << 16))
 | 
				
			||||||
 | 
					/* Port has hardware-assisted h/w flow control (iow, auto-RTS *not* auto-CTS) */
 | 
				
			||||||
 | 
					#define UPF_HARD_FLOW		((__force upf_t) (1 << 21))
 | 
				
			||||||
/* Port has hardware-assisted s/w flow control */
 | 
					/* Port has hardware-assisted s/w flow control */
 | 
				
			||||||
#define UPF_SOFT_FLOW		((__force upf_t) (1 << 22))
 | 
					#define UPF_SOFT_FLOW		((__force upf_t) (1 << 22))
 | 
				
			||||||
#define UPF_CONS_FLOW		((__force upf_t) (1 << 23))
 | 
					#define UPF_CONS_FLOW		((__force upf_t) (1 << 23))
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in a new issue