[PATCH] USB: iuu_phoenix: minimual version of set_termios.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



set_termios can now be used for setting the parity and the stopbits. This is
needed to use with cards which use a different parity then the parity used at
start (even).

If the iuu_uart_baud function return an error, we will return the old_termios
instead of the new one.

Signed-off-by: Olivier Bornet <Olivier.Bornet@xxxxxxx>
---
 drivers/usb/serial/iuu_phoenix.c |   43 ++++++++++++++++++++++++++++++++++++++
 1 files changed, 43 insertions(+), 0 deletions(-)

diff --git a/drivers/usb/serial/iuu_phoenix.c b/drivers/usb/serial/iuu_phoenix.c
index adcf26d..f280b0f 100644
--- a/drivers/usb/serial/iuu_phoenix.c
+++ b/drivers/usb/serial/iuu_phoenix.c
@@ -948,6 +948,48 @@ static int set_control_lines(struct usb_device *dev, u8 value)
 	return 0;
 }
 
+static void iuu_set_termios(struct tty_struct *tty,
+		struct usb_serial_port *port, struct ktermios *old_termios)
+{
+	/* FIXME: the current implementation of termios is very minimal... */
+	unsigned int cflag = tty->termios->c_cflag;
+	int status;
+	u32 actual;
+	u32 parity;
+
+	/* compute the parity parameter */
+	parity = 0;
+	parity |= (cflag & PARENB ?
+			(cflag & PARODD ? IUU_PARITY_ODD :
+			 IUU_PARITY_EVEN) :
+			IUU_PARITY_NONE);
+	parity |= (cflag & CSTOPB ? IUU_TWO_STOP_BITS : IUU_ONE_STOP_BIT);
+
+	/* set it */
+	status = iuu_uart_baud(port,
+			(clockmode == 2) ? 16457 : 9600 * boost / 100,
+			&actual, parity);
+
+	/* set the termios value to the real one, so the user now what has
+	 * changed */
+	if (old_termios) {
+		int i;
+		/* copy the old value... */
+		tty->termios->c_iflag = old_termios->c_iflag;
+		tty->termios->c_oflag = old_termios->c_oflag;
+		tty->termios->c_cflag = old_termios->c_cflag;
+		tty->termios->c_lflag = old_termios->c_lflag;
+		tty->termios->c_line = old_termios->c_line;
+		for (i = 0; i < NCCS; i++)
+			tty->termios->c_cc[i] = old_termios->c_cc[i];
+
+		if (status == 0)
+			/* all was ok, so update what we have changed */
+			tty->termios->c_cflag |= cflag & (PARENB
+					| PARODD | CSTOPB);
+	}
+}
+
 static void iuu_close(struct tty_struct *tty,
 			struct usb_serial_port *port, struct file *filp)
 {
@@ -1172,6 +1214,7 @@ static struct usb_serial_driver iuu_device = {
 	.read_bulk_callback = iuu_uart_read_callback,
 	.tiocmget = iuu_tiocmget,
 	.tiocmset = iuu_tiocmset,
+	.set_termios = iuu_set_termios,
 	.attach = iuu_startup,
 	.shutdown = iuu_shutdown,
 };
-- 
1.6.2.4

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux