Commit f548b96d authored by Alexander Shiyan's avatar Alexander Shiyan Committed by Greg Kroah-Hartman

serial: sccnxp: Reset break and overrun bits in RX handler

This patch adds a hardware reset the break and overflow bits for
these events. Without resetting the bits they will be reported to
the core every time, when once occur.
Signed-off-by: default avatarAlexander Shiyan <shc_work@mail.ru>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent c098020d
...@@ -305,14 +305,19 @@ static void sccnxp_handle_rx(struct uart_port *port) ...@@ -305,14 +305,19 @@ static void sccnxp_handle_rx(struct uart_port *port)
if (unlikely(sr)) { if (unlikely(sr)) {
if (sr & SR_BRK) { if (sr & SR_BRK) {
port->icount.brk++; port->icount.brk++;
sccnxp_port_write(port, SCCNXP_CR_REG,
CR_CMD_BREAK_RESET);
if (uart_handle_break(port)) if (uart_handle_break(port))
continue; continue;
} else if (sr & SR_PE) } else if (sr & SR_PE)
port->icount.parity++; port->icount.parity++;
else if (sr & SR_FE) else if (sr & SR_FE)
port->icount.frame++; port->icount.frame++;
else if (sr & SR_OVR) else if (sr & SR_OVR) {
port->icount.overrun++; port->icount.overrun++;
sccnxp_port_write(port, SCCNXP_CR_REG,
CR_CMD_STATUS_RESET);
}
sr &= port->read_status_mask; sr &= port->read_status_mask;
if (sr & SR_BRK) if (sr & SR_BRK)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment