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

Commit 0690f41f authored by Paul Gortmaker's avatar Paul Gortmaker Committed by Greg Kroah-Hartman
Browse files

serial: clean up parameter passing for 8250 Rx IRQ handling



The receive_chars() was taking a pointer to a passed in LSR value
in status and knocking off bits as it processed them.  But since
receive_chars isn't returning a value, we can instead pass in
a normal non-pointer value for LSR, and simply return the
residual (unprocessed) LSR once it is done.

The value in this cleanup, is that it clarifies the API of the
receive_chars prior to exporting it to other 8250-like drivers
for shared usage.

Signed-off-by: default avatarPaul Gortmaker <paul.gortmaker@windriver.com>
Acked-by: default avatarAlan Cox <alan@linux.intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 850624c1
Loading
Loading
Loading
Loading
+11 −6
Original line number Diff line number Diff line
@@ -1375,11 +1375,16 @@ static void clear_rx_fifo(struct uart_8250_port *up)
	} while (1);
}

static void
receive_chars(struct uart_8250_port *up, unsigned int *status)
/*
 * receive_chars: processes according to the passed in LSR
 * value, and returns the remaining LSR bits not handled
 * by this Rx routine.
 */
static unsigned char
receive_chars(struct uart_8250_port *up, unsigned char lsr)
{
	struct tty_struct *tty = up->port.state->port.tty;
	unsigned char ch, lsr = *status;
	unsigned char ch;
	int max_count = 256;
	char flag;

@@ -1455,7 +1460,7 @@ receive_chars(struct uart_8250_port *up, unsigned int *status)
	spin_unlock(&up->port.lock);
	tty_flip_buffer_push(tty);
	spin_lock(&up->port.lock);
	*status = lsr;
	return lsr;
}

static void transmit_chars(struct uart_8250_port *up)
@@ -1524,7 +1529,7 @@ static unsigned int check_modem_status(struct uart_8250_port *up)
 */
static void serial8250_handle_port(struct uart_8250_port *up)
{
	unsigned int status;
	unsigned char status;
	unsigned long flags;

	spin_lock_irqsave(&up->port.lock, flags);
@@ -1534,7 +1539,7 @@ static void serial8250_handle_port(struct uart_8250_port *up)
	DEBUG_INTR("status = %x...", status);

	if (status & (UART_LSR_DR | UART_LSR_BI))
		receive_chars(up, &status);
		status = receive_chars(up, status);
	check_modem_status(up);
	if (status & UART_LSR_THRE)
		transmit_chars(up);