Commit cae167d3 authored by Yutaro Ebihara's avatar Yutaro Ebihara Committed by Paul Mundt

serial: sh-sci: Fix fifo stall on SH7760/SH7780/SH7785 SCIF.

There was an off-by-1 in the SCRFDR calculation that caused writes over
128-bytes to hang in the FIFO. Fix it up.
Signed-off-by: default avatarYutaro Ebihara <ebiharaml@si-linux.com>
Signed-off-by: default avatarPaul Mundt <lethal@linux-sh.org>
parent 2f44bbb4
...@@ -414,12 +414,12 @@ static void sci_init_pins_scif(struct uart_port *port, unsigned int cflag) ...@@ -414,12 +414,12 @@ static void sci_init_pins_scif(struct uart_port *port, unsigned int cflag)
defined(CONFIG_CPU_SUBTYPE_SH7785) defined(CONFIG_CPU_SUBTYPE_SH7785)
static inline int scif_txroom(struct uart_port *port) static inline int scif_txroom(struct uart_port *port)
{ {
return SCIF_TXROOM_MAX - (sci_in(port, SCTFDR) & 0x7f); return SCIF_TXROOM_MAX - (sci_in(port, SCTFDR) & 0xff);
} }
static inline int scif_rxroom(struct uart_port *port) static inline int scif_rxroom(struct uart_port *port)
{ {
return sci_in(port, SCRFDR) & 0x7f; return sci_in(port, SCRFDR) & 0xff;
} }
#else #else
static inline int scif_txroom(struct uart_port *port) static inline int scif_txroom(struct uart_port *port)
......
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