Re: [PATCH 06/16] tty: serial: Add 8250-core based omap driver

From: Sebastian Andrzej Siewior
Date: Tue Sep 16 2014 - 13:01:40 EST


On 09/11/2014 01:57 PM, Peter Hurley wrote:
> Hi Sebastian,

Hi Peter,

> Nice work. Minor comments within.

Thanks.

> After this is merged, it may be worth investigating how to use Yoshihiro's
> newly-added 8250-based tunable RX trigger interface for omap.

We need to overwrite the FCR callback. First because we can support
trigger levels 1…64 and it it split across two registers and second
because a change here results also in different DMA attributes.

>> +++ b/drivers/tty/serial/8250/8250_omap.c
>> @@ -0,0 +1,911 @@
>> +/*
>> + * 8250-core based driver for the OMAP internal UART
>> + *
>> + * Copyright (C) 2014 Sebastian Andrzej Siewior
>
> + * based on omap-serial.c, Copyright (C) 2010 Texas Instruments.
>
> or something like that, since this is (partly) based on omap-serial.c

of course.

>> + *
>> + */
>> +

>> + /*
>> + * Ask the core to calculate the divisor for us.
>> + */
>> + baud = uart_get_baud_rate(port, termios, old,
>> + port->uartclk / 16 / 0xffff,
>> + port->uartclk / 13);
>> + omap_8250_get_divisor(port, baud, priv);
>> +
>> + /*
>> + * Ok, we're now changing the port state. Do it with
>> + * interrupts disabled.
>> + */
>> + pm_runtime_get_sync(port->dev);
>> + spin_lock_irqsave(&port->lock, flags);
> ^^^
> spin_lock_irq(&port->lock);
>
> The serial core calls the ->set_termios() method with interrupts enabled.

Okay, this could work.

>> +
>> + /*
>> + * Update the per-port timeout.
>> + */
>> + uart_update_timeout(port, termios->c_cflag, baud);
>> +
>> + up->port.read_status_mask = UART_LSR_OE | UART_LSR_THRE | UART_LSR_DR;
>> + if (termios->c_iflag & INPCK)
>> + up->port.read_status_mask |= UART_LSR_FE | UART_LSR_PE;
>> + if (termios->c_iflag & (BRKINT | PARMRK))
> ^
> IGNBRK |
>
> Otherwise, the read_status_mask will mask out the BI condition, so
> uart_insert_char() will send '\0' byte as TTY_NORMAL.
>
> The 8250 and omap RX path differed so the omap driver didn't need this
> change, whereas the 8250 driver does.

Updated.

>> + up->port.read_status_mask |= UART_LSR_BI;
>> +
>> + /*

>> +
>> + priv->efr = 0;
>> + if (termios->c_cflag & CRTSCTS && up->port.flags & UPF_HARD_FLOW) {
>> + /* Enable AUTORTS and AUTOCTS */
>> + priv->efr |= UART_EFR_CTS | UART_EFR_RTS;
>> +
>> + /* Ensure MCR RTS is asserted */
>> + up->mcr |= UART_MCR_RTS;
>> + }
>> +
>> + if (up->port.flags & UPF_SOFT_FLOW) {
>
> I'm aware that this is basically from the omap driver but can someone clear
> up if omap hardware can actually do UPF_HARD_FLOW and UPF_SOFT_FLOW
> simultaneously? The datasheets that I've looked at say no.

The one that I have here for am335x says:
"The UART module can use hardware or software flow control to manage
transmission and reception".
So yes, you are right about this. I changed this to do UPF_HARD_FLOW if
possible + else UPF_SOFT_FLOW.

> Regards,
> Peter Hurley

Sebastian
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/