Commit 3c2d0ed2 authored by Sonic Zhang's avatar Sonic Zhang Committed by Greg Kroah-Hartman

serial: bfin_uart: RTS and CTS MMRs can be either 16-bit width or 32-bit width.

Change hardware flow control code to adapt to both bf5xx and bf60x.
Disabled serial device before set termios for bf60x.
Signed-off-by: default avatarSonic Zhang <sonic.zhang@analog.com>
Signed-off-by: default avatarBob Liu <lliubbo@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 239c25b1
...@@ -549,7 +549,7 @@ static irqreturn_t bfin_serial_dma_tx_int(int irq, void *dev_id) ...@@ -549,7 +549,7 @@ static irqreturn_t bfin_serial_dma_tx_int(int irq, void *dev_id)
static irqreturn_t bfin_serial_dma_rx_int(int irq, void *dev_id) static irqreturn_t bfin_serial_dma_rx_int(int irq, void *dev_id)
{ {
struct bfin_serial_port *uart = dev_id; struct bfin_serial_port *uart = dev_id;
unsigned short irqstat; unsigned int irqstat;
int x_pos, pos; int x_pos, pos;
spin_lock(&uart->rx_lock); spin_lock(&uart->rx_lock);
...@@ -582,7 +582,7 @@ static irqreturn_t bfin_serial_dma_rx_int(int irq, void *dev_id) ...@@ -582,7 +582,7 @@ static irqreturn_t bfin_serial_dma_rx_int(int irq, void *dev_id)
static unsigned int bfin_serial_tx_empty(struct uart_port *port) static unsigned int bfin_serial_tx_empty(struct uart_port *port)
{ {
struct bfin_serial_port *uart = (struct bfin_serial_port *)port; struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
unsigned short lsr; unsigned int lsr;
lsr = UART_GET_LSR(uart); lsr = UART_GET_LSR(uart);
if (lsr & TEMT) if (lsr & TEMT)
...@@ -741,7 +741,7 @@ static int bfin_serial_startup(struct uart_port *port) ...@@ -741,7 +741,7 @@ static int bfin_serial_startup(struct uart_port *port)
} }
/* CTS RTS PINs are negative assertive. */ /* CTS RTS PINs are negative assertive. */
UART_PUT_MCR(uart, ACTS); UART_PUT_MCR(uart, UART_GET_MCR(uart) | ACTS);
UART_SET_IER(uart, EDSSI); UART_SET_IER(uart, EDSSI);
} }
#endif #endif
...@@ -799,7 +799,7 @@ bfin_serial_set_termios(struct uart_port *port, struct ktermios *termios, ...@@ -799,7 +799,7 @@ bfin_serial_set_termios(struct uart_port *port, struct ktermios *termios,
struct bfin_serial_port *uart = (struct bfin_serial_port *)port; struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
unsigned long flags; unsigned long flags;
unsigned int baud, quot; unsigned int baud, quot;
unsigned short val, ier, lcr = 0; unsigned int ier, lcr = 0;
switch (termios->c_cflag & CSIZE) { switch (termios->c_cflag & CSIZE) {
case CS8: case CS8:
...@@ -871,6 +871,7 @@ bfin_serial_set_termios(struct uart_port *port, struct ktermios *termios, ...@@ -871,6 +871,7 @@ bfin_serial_set_termios(struct uart_port *port, struct ktermios *termios,
/* Disable UART */ /* Disable UART */
ier = UART_GET_IER(uart); ier = UART_GET_IER(uart);
UART_PUT_GCTL(uart, UART_GET_GCTL(uart) & ~UCEN);
UART_DISABLE_INTS(uart); UART_DISABLE_INTS(uart);
/* Set DLAB in LCR to Access CLK */ /* Set DLAB in LCR to Access CLK */
...@@ -882,14 +883,11 @@ bfin_serial_set_termios(struct uart_port *port, struct ktermios *termios, ...@@ -882,14 +883,11 @@ bfin_serial_set_termios(struct uart_port *port, struct ktermios *termios,
/* Clear DLAB in LCR to Access THR RBR IER */ /* Clear DLAB in LCR to Access THR RBR IER */
UART_CLEAR_DLAB(uart); UART_CLEAR_DLAB(uart);
UART_PUT_LCR(uart, lcr); UART_PUT_LCR(uart, (UART_GET_LCR(uart) & ~LCR_MASK) | lcr);
/* Enable UART */ /* Enable UART */
UART_ENABLE_INTS(uart, ier); UART_ENABLE_INTS(uart, ier);
UART_PUT_GCTL(uart, UART_GET_GCTL(uart) | UCEN);
val = UART_GET_GCTL(uart);
val |= UCEN;
UART_PUT_GCTL(uart, val);
/* Port speed changed, update the per-port timeout. */ /* Port speed changed, update the per-port timeout. */
uart_update_timeout(port, termios->c_cflag, baud); uart_update_timeout(port, termios->c_cflag, baud);
...@@ -949,7 +947,7 @@ bfin_serial_verify_port(struct uart_port *port, struct serial_struct *ser) ...@@ -949,7 +947,7 @@ bfin_serial_verify_port(struct uart_port *port, struct serial_struct *ser)
static void bfin_serial_set_ldisc(struct uart_port *port, int ld) static void bfin_serial_set_ldisc(struct uart_port *port, int ld)
{ {
struct bfin_serial_port *uart = (struct bfin_serial_port *)port; struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
unsigned short val; unsigned int val;
switch (ld) { switch (ld) {
case N_IRDA: case N_IRDA:
...@@ -967,7 +965,7 @@ static void bfin_serial_set_ldisc(struct uart_port *port, int ld) ...@@ -967,7 +965,7 @@ static void bfin_serial_set_ldisc(struct uart_port *port, int ld)
static void bfin_serial_reset_irda(struct uart_port *port) static void bfin_serial_reset_irda(struct uart_port *port)
{ {
struct bfin_serial_port *uart = (struct bfin_serial_port *)port; struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
unsigned short val; unsigned int val;
val = UART_GET_GCTL(uart); val = UART_GET_GCTL(uart);
val &= ~(UMOD_MASK | RPOLC); val &= ~(UMOD_MASK | RPOLC);
...@@ -1065,7 +1063,7 @@ static void __init ...@@ -1065,7 +1063,7 @@ static void __init
bfin_serial_console_get_options(struct bfin_serial_port *uart, int *baud, bfin_serial_console_get_options(struct bfin_serial_port *uart, int *baud,
int *parity, int *bits) int *parity, int *bits)
{ {
unsigned short status; unsigned int status;
status = UART_GET_IER(uart) & (ERBFI | ETBEI); status = UART_GET_IER(uart) & (ERBFI | ETBEI);
if (status == (ERBFI | ETBEI)) { if (status == (ERBFI | ETBEI)) {
......
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