From: Tony Lindgren Date: Wed, 28 Feb 2007 12:34:11 +0000 (-0800) Subject: serial: 8250 changes for omap X-Git-Tag: v2.6.21-omap1~43^2~7 X-Git-Url: http://pilppa.com/gitweb/?a=commitdiff_plain;h=02ed0a345ac04b7c0247b3fafc7a4d04cd7a0b4d;p=linux-2.6-omap-h63xx.git serial: 8250 changes for omap 8250 changes for omap Signed-off-by: Tony Lindgren --- diff --git a/drivers/serial/8250.c b/drivers/serial/8250.c index c129a0e8e80..56ce8556b20 100644 --- a/drivers/serial/8250.c +++ b/drivers/serial/8250.c @@ -1404,7 +1404,11 @@ static irqreturn_t serial8250_interrupt(int irq, void *dev_id) DEBUG_INTR("end.\n"); +#ifdef CONFIG_ARCH_OMAP15XX + return IRQ_HANDLED; /* FIXME: iir status not ready on 1510 */ +#else return IRQ_RETVAL(handled); +#endif } /* @@ -2055,6 +2059,19 @@ serial8250_set_termios(struct uart_port *port, struct ktermios *termios, /* emulated UARTs (Lucent Venus 167x) need two steps */ serial_outp(up, UART_FCR, UART_FCR_ENABLE_FIFO); } + + /* Note that we need to set ECB to access write water mark + * bits. First allow FCR tx fifo write, then set fcr with + * possible TX fifo settings. */ + if (uart_config[up->port.type].flags & UART_CAP_EFR) { + serial_outp(up, UART_LCR, 0xbf); /* Access EFR */ + serial_outp(up, UART_EFR, UART_EFR_ECB); + serial_outp(up, UART_LCR, 0x0); /* Access FCR */ + serial_outp(up, UART_FCR, fcr); + serial_outp(up, UART_LCR, 0xbf); /* Access EFR */ + serial_outp(up, UART_EFR, 0); + serial_outp(up, UART_LCR, cval); /* Access FCR */ + } else serial_outp(up, UART_FCR, fcr); /* set fcr */ } serial8250_set_mctrl(&up->port, up->port.mctrl); @@ -2081,6 +2098,11 @@ static int serial8250_request_std_resource(struct uart_8250_port *up) unsigned int size = 8 << up->port.regshift; int ret = 0; +#ifdef CONFIG_ARCH_OMAP + if (is_omap_port((unsigned int)up->port.membase)) + size = 0x16 << up->port.regshift; +#endif + switch (up->port.iotype) { case UPIO_AU: size = 0x100000;