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

Commit ff11d078 authored by Maciej W. Rozycki's avatar Maciej W. Rozycki Committed by Linus Torvalds
Browse files

dz: clean up and improve the setup of termios settings



A set of changes to the way termios settings are propagated to the serial
port hardware.  The DZ11 only supports a selection of fixed baud settings,
so some requests may not be fulfilled.  Keep the old setting in such a case
and failing that resort to 9600bps.  Also add a missing update of the
transmit timeout.  And remove the explicit encoding of the line selected
from writes to the Line Parameters Register as it has been preencoded by
the ->set_termios() call already.  Finally, remove a duplicate macro for
the Receiver Enable bit.

Signed-off-by: default avatarMaciej W. Rozycki <macro@linux-mips.org>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Alan Cox <alan@lxorguk.ukuu.org.uk>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 789c7048
Loading
Loading
Loading
Loading
+54 −49
Original line number Original line Diff line number Diff line
@@ -128,8 +128,8 @@ static void dz_stop_rx(struct uart_port *uport)
{
{
	struct dz_port *dport = (struct dz_port *)uport;
	struct dz_port *dport = (struct dz_port *)uport;


	dport->cflag &= ~DZ_CREAD;
	dport->cflag &= ~DZ_RXENAB;
	dz_out(dport, DZ_LPR, dport->cflag | dport->port.line);
	dz_out(dport, DZ_LPR, dport->cflag);
}
}


static void dz_enable_ms(struct uart_port *port)
static void dz_enable_ms(struct uart_port *port)
@@ -464,12 +464,51 @@ static void dz_break_ctl(struct uart_port *uport, int break_state)
	spin_unlock_irqrestore(&uport->lock, flags);
	spin_unlock_irqrestore(&uport->lock, flags);
}
}


static int dz_encode_baud_rate(unsigned int baud)
{
	switch (baud) {
	case 50:
		return DZ_B50;
	case 75:
		return DZ_B75;
	case 110:
		return DZ_B110;
	case 134:
		return DZ_B134;
	case 150:
		return DZ_B150;
	case 300:
		return DZ_B300;
	case 600:
		return DZ_B600;
	case 1200:
		return DZ_B1200;
	case 1800:
		return DZ_B1800;
	case 2000:
		return DZ_B2000;
	case 2400:
		return DZ_B2400;
	case 3600:
		return DZ_B3600;
	case 4800:
		return DZ_B4800;
	case 7200:
		return DZ_B7200;
	case 9600:
		return DZ_B9600;
	default:
		return -1;
	}
}

static void dz_set_termios(struct uart_port *uport, struct ktermios *termios,
static void dz_set_termios(struct uart_port *uport, struct ktermios *termios,
			   struct ktermios *old_termios)
			   struct ktermios *old_termios)
{
{
	struct dz_port *dport = (struct dz_port *)uport;
	struct dz_port *dport = (struct dz_port *)uport;
	unsigned long flags;
	unsigned long flags;
	unsigned int cflag, baud;
	unsigned int cflag, baud;
	int bflag;


	cflag = dport->port.line;
	cflag = dport->port.line;


@@ -496,60 +535,26 @@ static void dz_set_termios(struct uart_port *uport, struct ktermios *termios,
		cflag |= DZ_PARODD;
		cflag |= DZ_PARODD;


	baud = uart_get_baud_rate(uport, termios, old_termios, 50, 9600);
	baud = uart_get_baud_rate(uport, termios, old_termios, 50, 9600);
	switch (baud) {
	bflag = dz_encode_baud_rate(baud);
	case 50:
	if (bflag < 0)	{			/* Try to keep unchanged.  */
		cflag |= DZ_B50;
		baud = uart_get_baud_rate(uport, old_termios, NULL, 50, 9600);
		break;
		bflag = dz_encode_baud_rate(baud);
	case 75:
		if (bflag < 0)	{		/* Resort to 9600.  */
		cflag |= DZ_B75;
			baud = 9600;
		break;
			bflag = DZ_B9600;
	case 110:
		}
		cflag |= DZ_B110;
		tty_termios_encode_baud_rate(termios, baud, baud);
		break;
	case 134:
		cflag |= DZ_B134;
		break;
	case 150:
		cflag |= DZ_B150;
		break;
	case 300:
		cflag |= DZ_B300;
		break;
	case 600:
		cflag |= DZ_B600;
		break;
	case 1200:
		cflag |= DZ_B1200;
		break;
	case 1800:
		cflag |= DZ_B1800;
		break;
	case 2000:
		cflag |= DZ_B2000;
		break;
	case 2400:
		cflag |= DZ_B2400;
		break;
	case 3600:
		cflag |= DZ_B3600;
		break;
	case 4800:
		cflag |= DZ_B4800;
		break;
	case 7200:
		cflag |= DZ_B7200;
		break;
	case 9600:
	default:
		cflag |= DZ_B9600;
	}
	}
	cflag |= bflag;


	if (termios->c_cflag & CREAD)
	if (termios->c_cflag & CREAD)
		cflag |= DZ_RXENAB;
		cflag |= DZ_RXENAB;


	spin_lock_irqsave(&dport->port.lock, flags);
	spin_lock_irqsave(&dport->port.lock, flags);


	dz_out(dport, DZ_LPR, cflag | dport->port.line);
	uart_update_timeout(uport, termios->c_cflag, baud);

	dz_out(dport, DZ_LPR, cflag);
	dport->cflag = cflag;
	dport->cflag = cflag;


	/* setup accept flag */
	/* setup accept flag */
+2 −2
Original line number Original line Diff line number Diff line
@@ -109,8 +109,8 @@
#define DZ_B7200         0x0D00
#define DZ_B7200         0x0D00
#define DZ_B9600         0x0E00
#define DZ_B9600         0x0E00


#define DZ_CREAD         0x1000               /* Enable receiver */
#define DZ_RXENAB        0x1000               /* Receiver Enable */
#define DZ_RXENAB        0x1000               /* enable receive char */

/*
/*
 * Addresses for the DZ registers
 * Addresses for the DZ registers
 */
 */