Commit 59bd234b authored by Sonic Zhang's avatar Sonic Zhang Committed by Greg Kroah-Hartman

serial: bfin_uart: Make MMR access compatible with 32 bits bf609 style controller.

Simplify serial data width calculation and adapt to bf609 LCR bit mask.
Signed-off-by: default avatarSonic Zhang <sonic.zhang@analog.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 3c2d0ed2
...@@ -594,7 +594,7 @@ static unsigned int bfin_serial_tx_empty(struct uart_port *port) ...@@ -594,7 +594,7 @@ static unsigned int bfin_serial_tx_empty(struct uart_port *port)
static void bfin_serial_break_ctl(struct uart_port *port, int break_state) static void bfin_serial_break_ctl(struct uart_port *port, int break_state)
{ {
struct bfin_serial_port *uart = (struct bfin_serial_port *)port; struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
u16 lcr = UART_GET_LCR(uart); u32 lcr = UART_GET_LCR(uart);
if (break_state) if (break_state)
lcr |= SB; lcr |= SB;
else else
...@@ -1068,7 +1068,7 @@ bfin_serial_console_get_options(struct bfin_serial_port *uart, int *baud, ...@@ -1068,7 +1068,7 @@ bfin_serial_console_get_options(struct bfin_serial_port *uart, int *baud,
status = UART_GET_IER(uart) & (ERBFI | ETBEI); status = UART_GET_IER(uart) & (ERBFI | ETBEI);
if (status == (ERBFI | ETBEI)) { if (status == (ERBFI | ETBEI)) {
/* ok, the port was enabled */ /* ok, the port was enabled */
u16 lcr, clk; u32 lcr, clk;
lcr = UART_GET_LCR(uart); lcr = UART_GET_LCR(uart);
...@@ -1079,20 +1079,8 @@ bfin_serial_console_get_options(struct bfin_serial_port *uart, int *baud, ...@@ -1079,20 +1079,8 @@ bfin_serial_console_get_options(struct bfin_serial_port *uart, int *baud,
else else
*parity = 'o'; *parity = 'o';
} }
switch (lcr & 0x03) { *bits = ((lcr & WLS_MASK) >> WLS_OFFSET) + 5;
case 0:
*bits = 5;
break;
case 1:
*bits = 6;
break;
case 2:
*bits = 7;
break;
case 3:
*bits = 8;
break;
}
/* Set DLAB in LCR to Access CLK */ /* Set DLAB in LCR to Access CLK */
UART_SET_DLAB(uart); UART_SET_DLAB(uart);
......
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