diff options
author | Alan Cox <alan@linux.intel.com> | 2012-07-14 10:31:47 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2012-07-16 16:00:41 -0400 |
commit | adc8d746caa67fff4b53ba3e5163a6cbacc3b523 (patch) | |
tree | e3f6c05f27c163b369ddd4da5f31d2a61bde6d3a /drivers/tty/tty_port.c | |
parent | 6d31a88cb2e01d46c0cb74aa5da529e1f92ae3db (diff) |
tty: move the termios object into the tty
This will let us sort out a whole pile of tty related races. The
alternative would be to keep points and refcount the termios objects.
However
1. They are tiny anyway
2. Many devices don't use the stored copies
3. We can remove a pty special case
Signed-off-by: Alan Cox <alan@linux.intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/tty/tty_port.c')
-rw-r--r-- | drivers/tty/tty_port.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/drivers/tty/tty_port.c b/drivers/tty/tty_port.c index 4e9d2b291f4a..edcb827c1286 100644 --- a/drivers/tty/tty_port.c +++ b/drivers/tty/tty_port.c | |||
@@ -255,7 +255,7 @@ int tty_port_block_til_ready(struct tty_port *port, | |||
255 | } | 255 | } |
256 | if (filp->f_flags & O_NONBLOCK) { | 256 | if (filp->f_flags & O_NONBLOCK) { |
257 | /* Indicate we are open */ | 257 | /* Indicate we are open */ |
258 | if (tty->termios->c_cflag & CBAUD) | 258 | if (tty->termios.c_cflag & CBAUD) |
259 | tty_port_raise_dtr_rts(port); | 259 | tty_port_raise_dtr_rts(port); |
260 | port->flags |= ASYNC_NORMAL_ACTIVE; | 260 | port->flags |= ASYNC_NORMAL_ACTIVE; |
261 | return 0; | 261 | return 0; |
@@ -279,7 +279,7 @@ int tty_port_block_til_ready(struct tty_port *port, | |||
279 | 279 | ||
280 | while (1) { | 280 | while (1) { |
281 | /* Indicate we are open */ | 281 | /* Indicate we are open */ |
282 | if (tty->termios->c_cflag & CBAUD) | 282 | if (tty->termios.c_cflag & CBAUD) |
283 | tty_port_raise_dtr_rts(port); | 283 | tty_port_raise_dtr_rts(port); |
284 | 284 | ||
285 | prepare_to_wait(&port->open_wait, &wait, TASK_INTERRUPTIBLE); | 285 | prepare_to_wait(&port->open_wait, &wait, TASK_INTERRUPTIBLE); |
@@ -378,7 +378,7 @@ int tty_port_close_start(struct tty_port *port, | |||
378 | 378 | ||
379 | /* Drop DTR/RTS if HUPCL is set. This causes any attached modem to | 379 | /* Drop DTR/RTS if HUPCL is set. This causes any attached modem to |
380 | hang up the line */ | 380 | hang up the line */ |
381 | if (tty->termios->c_cflag & HUPCL) | 381 | if (tty->termios.c_cflag & HUPCL) |
382 | tty_port_lower_dtr_rts(port); | 382 | tty_port_lower_dtr_rts(port); |
383 | 383 | ||
384 | /* Don't call port->drop for the last reference. Callers will want | 384 | /* Don't call port->drop for the last reference. Callers will want |