aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/tty/serial/xilinx_uartps.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/drivers/tty/serial/xilinx_uartps.c b/drivers/tty/serial/xilinx_uartps.c
index 74089f5e5b53..605354fd60b1 100644
--- a/drivers/tty/serial/xilinx_uartps.c
+++ b/drivers/tty/serial/xilinx_uartps.c
@@ -193,6 +193,7 @@ struct cdns_uart {
193 int id; 193 int id;
194 struct notifier_block clk_rate_change_nb; 194 struct notifier_block clk_rate_change_nb;
195 u32 quirks; 195 u32 quirks;
196 bool cts_override;
196}; 197};
197struct cdns_platform_data { 198struct cdns_platform_data {
198 u32 quirks; 199 u32 quirks;
@@ -1000,6 +1001,11 @@ static void cdns_uart_config_port(struct uart_port *port, int flags)
1000 */ 1001 */
1001static unsigned int cdns_uart_get_mctrl(struct uart_port *port) 1002static unsigned int cdns_uart_get_mctrl(struct uart_port *port)
1002{ 1003{
1004 struct cdns_uart *cdns_uart_data = port->private_data;
1005
1006 if (cdns_uart_data->cts_override)
1007 return 0;
1008
1003 return TIOCM_CTS | TIOCM_DSR | TIOCM_CAR; 1009 return TIOCM_CTS | TIOCM_DSR | TIOCM_CAR;
1004} 1010}
1005 1011
@@ -1007,6 +1013,10 @@ static void cdns_uart_set_mctrl(struct uart_port *port, unsigned int mctrl)
1007{ 1013{
1008 u32 val; 1014 u32 val;
1009 u32 mode_reg; 1015 u32 mode_reg;
1016 struct cdns_uart *cdns_uart_data = port->private_data;
1017
1018 if (cdns_uart_data->cts_override)
1019 return;
1010 1020
1011 val = readl(port->membase + CDNS_UART_MODEMCR); 1021 val = readl(port->membase + CDNS_UART_MODEMCR);
1012 mode_reg = readl(port->membase + CDNS_UART_MR); 1022 mode_reg = readl(port->membase + CDNS_UART_MR);
@@ -1665,6 +1675,8 @@ static int cdns_uart_probe(struct platform_device *pdev)
1665 console_port = NULL; 1675 console_port = NULL;
1666#endif 1676#endif
1667 1677
1678 cdns_uart_data->cts_override = of_property_read_bool(pdev->dev.of_node,
1679 "cts-override");
1668 return 0; 1680 return 0;
1669 1681
1670err_out_pm_disable: 1682err_out_pm_disable: