Re: [PATCH] serial: mxs-auart: support CMSPAR termios cflag
From: Wolfgang Ocker
Date: Tue Dec 06 2016 - 10:56:51 EST
On Tue, 2016-12-06 at 14:36 +0100, Stefan Wahren wrote:
> Hi Wolfgang,
>
> > --- a/drivers/tty/serial/mxs-auart.c
> > +++ b/drivers/tty/serial/mxs-auart.c
> > @@ -95,6 +95,7 @@
> > Â#define AUART_LINECTRL_BAUD_DIVFRAC_SHIFT 8
> > Â#define AUART_LINECTRL_BAUD_DIVFRAC_MASK 0x00003f00
> > Â#define AUART_LINECTRL_BAUD_DIVFRAC(v) (((v) & 0x3f) << 8)
> > +#define AUART_LINECTRL_SPS (1 << 7)
> > Â#define AUART_LINECTRL_WLEN_MASK 0x00000060
> > Â#define AUART_LINECTRL_WLEN(v) (((v) & 0x3) << 5)
> > Â#define AUART_LINECTRL_FEN (1 << 4)
> > @@ -1010,10 +1011,12 @@ static void mxs_auart_settermios(struct uart_port
> > *u,
> > ctrl |= AUART_LINECTRL_WLEN(bm);
> >
> > /* parity */
> > - if (cflag & PARENB) {
> > + if (cflag & (PARENB|CMSPAR)) {
>
> does it make sense to enable stick parity in case parity is disabled?
>
> The i.MX28 reference manual doesn't describe this case explicit.
Thanks Stefan for the hint. I think it's okay on the hardware side since the
PEN bit is always set and therefore it can not happen that SPS is set but not
PEN.
But on the termios side it makes sense to require PARENB to be set in c_cflag
if CMSPAR is requested.
So I will provide an updated patch soon.
Wolfgang