Revert "tty/serial/8250: use mctrl_gpio helpers"

Serial console is broken in v4.8-rcX. Mika and I independently bisected down to
commit 4ef03d328769 ("tty/serial/8250: use mctrl_gpio helpers").

Since neither author nor anyone else didn't propose a solution we better revert
it for now.

This reverts commit 4ef03d328769eddbfeca1f1c958fdb181a69c341.

Link: https://lkml.kernel.org/r/20160809130229.GN1729@lahna.fi.intel.com
Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Tested-by: Heikki Krogerus <heikki.krogerus@linux.intel.com>
Tested-by: Mika Westerberg <mika.westerberg@linux.intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
Andy Shevchenko 2016-08-16 15:06:54 +03:00 committed by Greg Kroah-Hartman
parent 87a713c8ff
commit 5db4f7f80d
7 changed files with 15 additions and 88 deletions

View File

@ -42,9 +42,6 @@ Optional properties:
- auto-flow-control: one way to enable automatic flow control support. The - auto-flow-control: one way to enable automatic flow control support. The
driver is allowed to detect support for the capability even without this driver is allowed to detect support for the capability even without this
property. property.
- {rts,cts,dtr,dsr,rng,dcd}-gpios: specify a GPIO for RTS/CTS/DTR/DSR/RI/DCD
line respectively. It will use specified GPIO instead of the peripheral
function pin for the UART feature. If unsure, don't specify this property.
Note: Note:
* fsl,ns16550: * fsl,ns16550:
@ -66,19 +63,3 @@ Example:
interrupts = <10>; interrupts = <10>;
reg-shift = <2>; reg-shift = <2>;
}; };
Example for OMAP UART using GPIO-based modem control signals:
uart4: serial@49042000 {
compatible = "ti,omap3-uart";
reg = <0x49042000 0x400>;
interrupts = <80>;
ti,hwmods = "uart4";
clock-frequency = <48000000>;
cts-gpios = <&gpio3 5 GPIO_ACTIVE_LOW>;
rts-gpios = <&gpio3 6 GPIO_ACTIVE_LOW>;
dtr-gpios = <&gpio1 12 GPIO_ACTIVE_LOW>;
dsr-gpios = <&gpio1 13 GPIO_ACTIVE_LOW>;
dcd-gpios = <&gpio1 14 GPIO_ACTIVE_LOW>;
rng-gpios = <&gpio1 15 GPIO_ACTIVE_LOW>;
};

View File

@ -15,8 +15,6 @@
#include <linux/serial_reg.h> #include <linux/serial_reg.h>
#include <linux/dmaengine.h> #include <linux/dmaengine.h>
#include "../serial_mctrl_gpio.h"
struct uart_8250_dma { struct uart_8250_dma {
int (*tx_dma)(struct uart_8250_port *p); int (*tx_dma)(struct uart_8250_port *p);
int (*rx_dma)(struct uart_8250_port *p); int (*rx_dma)(struct uart_8250_port *p);
@ -133,43 +131,12 @@ void serial8250_em485_destroy(struct uart_8250_port *p);
static inline void serial8250_out_MCR(struct uart_8250_port *up, int value) static inline void serial8250_out_MCR(struct uart_8250_port *up, int value)
{ {
int mctrl_gpio = 0;
serial_out(up, UART_MCR, value); serial_out(up, UART_MCR, value);
if (value & UART_MCR_RTS)
mctrl_gpio |= TIOCM_RTS;
if (value & UART_MCR_DTR)
mctrl_gpio |= TIOCM_DTR;
mctrl_gpio_set(up->gpios, mctrl_gpio);
} }
static inline int serial8250_in_MCR(struct uart_8250_port *up) static inline int serial8250_in_MCR(struct uart_8250_port *up)
{ {
int mctrl, mctrl_gpio = 0; return serial_in(up, UART_MCR);
mctrl = serial_in(up, UART_MCR);
/* save current MCR values */
if (mctrl & UART_MCR_RTS)
mctrl_gpio |= TIOCM_RTS;
if (mctrl & UART_MCR_DTR)
mctrl_gpio |= TIOCM_DTR;
mctrl_gpio = mctrl_gpio_get_outputs(up->gpios, &mctrl_gpio);
if (mctrl_gpio & TIOCM_RTS)
mctrl |= UART_MCR_RTS;
else
mctrl &= ~UART_MCR_RTS;
if (mctrl_gpio & TIOCM_DTR)
mctrl |= UART_MCR_DTR;
else
mctrl &= ~UART_MCR_DTR;
return mctrl;
} }
#if defined(__alpha__) && !defined(CONFIG_PCI) #if defined(__alpha__) && !defined(CONFIG_PCI)

View File

@ -974,8 +974,6 @@ int serial8250_register_8250_port(struct uart_8250_port *up)
uart = serial8250_find_match_or_unused(&up->port); uart = serial8250_find_match_or_unused(&up->port);
if (uart && uart->port.type != PORT_8250_CIR) { if (uart && uart->port.type != PORT_8250_CIR) {
struct mctrl_gpios *gpios;
if (uart->port.dev) if (uart->port.dev)
uart_remove_one_port(&serial8250_reg, &uart->port); uart_remove_one_port(&serial8250_reg, &uart->port);
@ -1013,13 +1011,6 @@ int serial8250_register_8250_port(struct uart_8250_port *up)
if (up->port.flags & UPF_FIXED_TYPE) if (up->port.flags & UPF_FIXED_TYPE)
uart->port.type = up->port.type; uart->port.type = up->port.type;
gpios = mctrl_gpio_init(&uart->port, 0);
if (IS_ERR(gpios)) {
if (PTR_ERR(gpios) != -ENOSYS)
return PTR_ERR(gpios);
} else
uart->gpios = gpios;
serial8250_set_defaults(uart); serial8250_set_defaults(uart);
/* Possibly override default I/O functions. */ /* Possibly override default I/O functions. */

View File

@ -134,21 +134,18 @@ static void omap8250_set_mctrl(struct uart_port *port, unsigned int mctrl)
serial8250_do_set_mctrl(port, mctrl); serial8250_do_set_mctrl(port, mctrl);
if (IS_ERR_OR_NULL(mctrl_gpio_to_gpiod(up->gpios, /*
UART_GPIO_RTS))) { * Turn off autoRTS if RTS is lowered and restore autoRTS setting
/* * if RTS is raised
* Turn off autoRTS if RTS is lowered and restore autoRTS */
* setting if RTS is raised lcr = serial_in(up, UART_LCR);
*/ serial_out(up, UART_LCR, UART_LCR_CONF_MODE_B);
lcr = serial_in(up, UART_LCR); if ((mctrl & TIOCM_RTS) && (port->status & UPSTAT_AUTORTS))
serial_out(up, UART_LCR, UART_LCR_CONF_MODE_B); priv->efr |= UART_EFR_RTS;
if ((mctrl & TIOCM_RTS) && (port->status & UPSTAT_AUTORTS)) else
priv->efr |= UART_EFR_RTS; priv->efr &= ~UART_EFR_RTS;
else serial_out(up, UART_EFR, priv->efr);
priv->efr &= ~UART_EFR_RTS; serial_out(up, UART_LCR, lcr);
serial_out(up, UART_EFR, priv->efr);
serial_out(up, UART_LCR, lcr);
}
} }
/* /*
@ -449,9 +446,7 @@ static void omap_8250_set_termios(struct uart_port *port,
priv->efr = 0; priv->efr = 0;
up->port.status &= ~(UPSTAT_AUTOCTS | UPSTAT_AUTORTS | UPSTAT_AUTOXOFF); up->port.status &= ~(UPSTAT_AUTOCTS | UPSTAT_AUTORTS | UPSTAT_AUTOXOFF);
if (termios->c_cflag & CRTSCTS && up->port.flags & UPF_HARD_FLOW if (termios->c_cflag & CRTSCTS && up->port.flags & UPF_HARD_FLOW) {
&& IS_ERR_OR_NULL(mctrl_gpio_to_gpiod(up->gpios,
UART_GPIO_RTS))) {
/* Enable AUTOCTS (autoRTS is enabled when RTS is raised) */ /* Enable AUTOCTS (autoRTS is enabled when RTS is raised) */
up->port.status |= UPSTAT_AUTOCTS | UPSTAT_AUTORTS; up->port.status |= UPSTAT_AUTOCTS | UPSTAT_AUTORTS;
priv->efr |= UART_EFR_CTS; priv->efr |= UART_EFR_CTS;

View File

@ -1618,8 +1618,6 @@ static void serial8250_disable_ms(struct uart_port *port)
if (up->bugs & UART_BUG_NOMSR) if (up->bugs & UART_BUG_NOMSR)
return; return;
mctrl_gpio_disable_ms(up->gpios);
up->ier &= ~UART_IER_MSI; up->ier &= ~UART_IER_MSI;
serial_port_out(port, UART_IER, up->ier); serial_port_out(port, UART_IER, up->ier);
} }
@ -1632,8 +1630,6 @@ static void serial8250_enable_ms(struct uart_port *port)
if (up->bugs & UART_BUG_NOMSR) if (up->bugs & UART_BUG_NOMSR)
return; return;
mctrl_gpio_enable_ms(up->gpios);
up->ier |= UART_IER_MSI; up->ier |= UART_IER_MSI;
serial8250_rpm_get(up); serial8250_rpm_get(up);
@ -1917,8 +1913,7 @@ unsigned int serial8250_do_get_mctrl(struct uart_port *port)
ret |= TIOCM_DSR; ret |= TIOCM_DSR;
if (status & UART_MSR_CTS) if (status & UART_MSR_CTS)
ret |= TIOCM_CTS; ret |= TIOCM_CTS;
return ret;
return mctrl_gpio_get(up->gpios, &ret);
} }
EXPORT_SYMBOL_GPL(serial8250_do_get_mctrl); EXPORT_SYMBOL_GPL(serial8250_do_get_mctrl);

View File

@ -6,7 +6,6 @@
config SERIAL_8250 config SERIAL_8250
tristate "8250/16550 and compatible serial support" tristate "8250/16550 and compatible serial support"
select SERIAL_CORE select SERIAL_CORE
select SERIAL_MCTRL_GPIO if GPIOLIB
---help--- ---help---
This selects whether you want to include the driver for the standard This selects whether you want to include the driver for the standard
serial ports. The standard answer is Y. People who might say N serial ports. The standard answer is Y. People who might say N

View File

@ -111,7 +111,6 @@ struct uart_8250_port {
* if no_console_suspend * if no_console_suspend
*/ */
unsigned char probe; unsigned char probe;
struct mctrl_gpios *gpios;
#define UART_PROBE_RSA (1 << 0) #define UART_PROBE_RSA (1 << 0)
/* /*