[PATCH v3 1/1] tty: serial: imx: allow breaks to be received when using dma
Uwe Kleine-König
u.kleine-koenig at pengutronix.de
Wed Feb 21 00:17:47 PST 2018
Hello Troy,
On Tue, Feb 20, 2018 at 12:25:16PM -0800, Troy Kisky wrote:
> >> @@ -1028,6 +1027,7 @@ static int start_rx_dma(struct imx_port *sport)
> >>
> >> static void clear_rx_errors(struct imx_port *sport)
> >> {
> >> + struct tty_port *port = &sport->port.state->port;
> >> unsigned int status_usr1, status_usr2;
> >>
> >> status_usr1 = readl(sport->port.membase + USR1);
> >> @@ -1036,12 +1036,18 @@ static void clear_rx_errors(struct imx_port *sport)
> >> if (status_usr2 & USR2_BRCD) {
> >> sport->port.icount.brk++;
> >> writel(USR2_BRCD, sport->port.membase + USR2);
> >> - } else if (status_usr1 & USR1_FRAMERR) {
> >> - sport->port.icount.frame++;
> >> - writel(USR1_FRAMERR, sport->port.membase + USR1);
> >> - } else if (status_usr1 & USR1_PARITYERR) {
> >> - sport->port.icount.parity++;
> >> - writel(USR1_PARITYERR, sport->port.membase + USR1);
> >> + if (tty_insert_flip_char(port, 0, TTY_BREAK) == 0)
> >> + sport->port.icount.buf_overrun++;
> >> + tty_flip_buffer_push(port);
> >
> > I think this needs to call uart_handle_break() as imx_rxint() does. Not sure
> > how to properly handle SYSRQ in the dma case though.
> >
>
>
> SYSRQ is only for the console port, and console port is never dma. But UPF_SAK may be
> an issue. I don't know enough about "Secure Attention Key" to say.
>
>
> Should I add uart_handle_break anyway ?
You're right about both SYSRQ and SAK. I think uart_handle_break is the
right one for the latter.
Best regards
Uwe
--
Pengutronix e.K. | Uwe Kleine-König |
Industrial Linux Solutions | http://www.pengutronix.de/ |
More information about the linux-arm-kernel
mailing list