Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

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

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
Loading
Loading
Loading
Loading
+4 −16
Original line number Diff line number Diff line
@@ -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)
{
	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)
		lcr |= SB;
	else
@@ -1068,7 +1068,7 @@ bfin_serial_console_get_options(struct bfin_serial_port *uart, int *baud,
	status = UART_GET_IER(uart) & (ERBFI | ETBEI);
	if (status == (ERBFI | ETBEI)) {
		/* ok, the port was enabled */
		u16 lcr, clk;
		u32 lcr, clk;

		lcr = UART_GET_LCR(uart);

@@ -1079,20 +1079,8 @@ bfin_serial_console_get_options(struct bfin_serial_port *uart, int *baud,
			else
				*parity = 'o';
		}
		switch (lcr & 0x03) {
		case 0:
			*bits = 5;
			break;
		case 1:
			*bits = 6;
			break;
		case 2:
			*bits = 7;
			break;
		case 3:
			*bits = 8;
			break;
		}
		*bits = ((lcr & WLS_MASK) >> WLS_OFFSET) + 5;

		/* Set DLAB in LCR to Access CLK */
		UART_SET_DLAB(uart);