aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/isdn/i4l/isdn_tty.c60
-rw-r--r--include/linux/isdn.h3
2 files changed, 33 insertions, 30 deletions
diff --git a/drivers/isdn/i4l/isdn_tty.c b/drivers/isdn/i4l/isdn_tty.c
index 74b05188c18f..8ba526dc98bc 100644
--- a/drivers/isdn/i4l/isdn_tty.c
+++ b/drivers/isdn/i4l/isdn_tty.c
@@ -1046,20 +1046,20 @@ isdn_tty_change_speed(modem_info *info)
1046 1046
1047 /* CTS flow control flag and modem status interrupts */ 1047 /* CTS flow control flag and modem status interrupts */
1048 if (cflag & CRTSCTS) { 1048 if (cflag & CRTSCTS) {
1049 info->flags |= ASYNC_CTS_FLOW; 1049 info->port.flags |= ASYNC_CTS_FLOW;
1050 } else 1050 } else
1051 info->flags &= ~ASYNC_CTS_FLOW; 1051 info->port.flags &= ~ASYNC_CTS_FLOW;
1052 if (cflag & CLOCAL) 1052 if (cflag & CLOCAL)
1053 info->flags &= ~ASYNC_CHECK_CD; 1053 info->port.flags &= ~ASYNC_CHECK_CD;
1054 else { 1054 else {
1055 info->flags |= ASYNC_CHECK_CD; 1055 info->port.flags |= ASYNC_CHECK_CD;
1056 } 1056 }
1057} 1057}
1058 1058
1059static int 1059static int
1060isdn_tty_startup(modem_info *info) 1060isdn_tty_startup(modem_info *info)
1061{ 1061{
1062 if (info->flags & ASYNC_INITIALIZED) 1062 if (info->port.flags & ASYNC_INITIALIZED)
1063 return 0; 1063 return 0;
1064 isdn_lock_drivers(); 1064 isdn_lock_drivers();
1065#ifdef ISDN_DEBUG_MODEM_OPEN 1065#ifdef ISDN_DEBUG_MODEM_OPEN
@@ -1076,7 +1076,7 @@ isdn_tty_startup(modem_info *info)
1076 */ 1076 */
1077 isdn_tty_change_speed(info); 1077 isdn_tty_change_speed(info);
1078 1078
1079 info->flags |= ASYNC_INITIALIZED; 1079 info->port.flags |= ASYNC_INITIALIZED;
1080 info->msr |= (UART_MSR_DSR | UART_MSR_CTS); 1080 info->msr |= (UART_MSR_DSR | UART_MSR_CTS);
1081 info->send_outstanding = 0; 1081 info->send_outstanding = 0;
1082 return 0; 1082 return 0;
@@ -1089,7 +1089,7 @@ isdn_tty_startup(modem_info *info)
1089static void 1089static void
1090isdn_tty_shutdown(modem_info *info) 1090isdn_tty_shutdown(modem_info *info)
1091{ 1091{
1092 if (!(info->flags & ASYNC_INITIALIZED)) 1092 if (!(info->port.flags & ASYNC_INITIALIZED))
1093 return; 1093 return;
1094#ifdef ISDN_DEBUG_MODEM_OPEN 1094#ifdef ISDN_DEBUG_MODEM_OPEN
1095 printk(KERN_DEBUG "Shutting down isdnmodem port %d ....\n", info->line); 1095 printk(KERN_DEBUG "Shutting down isdnmodem port %d ....\n", info->line);
@@ -1109,7 +1109,7 @@ isdn_tty_shutdown(modem_info *info)
1109 if (info->tty) 1109 if (info->tty)
1110 set_bit(TTY_IO_ERROR, &info->tty->flags); 1110 set_bit(TTY_IO_ERROR, &info->tty->flags);
1111 1111
1112 info->flags &= ~ASYNC_INITIALIZED; 1112 info->port.flags &= ~ASYNC_INITIALIZED;
1113} 1113}
1114 1114
1115/* isdn_tty_write() is the main send-routine. It is called from the upper 1115/* isdn_tty_write() is the main send-routine. It is called from the upper
@@ -1496,11 +1496,11 @@ isdn_tty_block_til_ready(struct tty_struct *tty, struct file *filp, modem_info *
1496 * until it's done, and then try again. 1496 * until it's done, and then try again.
1497 */ 1497 */
1498 if (tty_hung_up_p(filp) || 1498 if (tty_hung_up_p(filp) ||
1499 (info->flags & ASYNC_CLOSING)) { 1499 (info->port.flags & ASYNC_CLOSING)) {
1500 if (info->flags & ASYNC_CLOSING) 1500 if (info->port.flags & ASYNC_CLOSING)
1501 interruptible_sleep_on(&info->close_wait); 1501 interruptible_sleep_on(&info->close_wait);
1502#ifdef MODEM_DO_RESTART 1502#ifdef MODEM_DO_RESTART
1503 if (info->flags & ASYNC_HUP_NOTIFY) 1503 if (info->port.flags & ASYNC_HUP_NOTIFY)
1504 return -EAGAIN; 1504 return -EAGAIN;
1505 else 1505 else
1506 return -ERESTARTSYS; 1506 return -ERESTARTSYS;
@@ -1514,7 +1514,7 @@ isdn_tty_block_til_ready(struct tty_struct *tty, struct file *filp, modem_info *
1514 */ 1514 */
1515 if ((filp->f_flags & O_NONBLOCK) || 1515 if ((filp->f_flags & O_NONBLOCK) ||
1516 (tty->flags & (1 << TTY_IO_ERROR))) { 1516 (tty->flags & (1 << TTY_IO_ERROR))) {
1517 info->flags |= ASYNC_NORMAL_ACTIVE; 1517 info->port.flags |= ASYNC_NORMAL_ACTIVE;
1518 return 0; 1518 return 0;
1519 } 1519 }
1520 if (tty->termios->c_cflag & CLOCAL) 1520 if (tty->termios->c_cflag & CLOCAL)
@@ -1538,9 +1538,9 @@ isdn_tty_block_til_ready(struct tty_struct *tty, struct file *filp, modem_info *
1538 while (1) { 1538 while (1) {
1539 set_current_state(TASK_INTERRUPTIBLE); 1539 set_current_state(TASK_INTERRUPTIBLE);
1540 if (tty_hung_up_p(filp) || 1540 if (tty_hung_up_p(filp) ||
1541 !(info->flags & ASYNC_INITIALIZED)) { 1541 !(info->port.flags & ASYNC_INITIALIZED)) {
1542#ifdef MODEM_DO_RESTART 1542#ifdef MODEM_DO_RESTART
1543 if (info->flags & ASYNC_HUP_NOTIFY) 1543 if (info->port.flags & ASYNC_HUP_NOTIFY)
1544 retval = -EAGAIN; 1544 retval = -EAGAIN;
1545 else 1545 else
1546 retval = -ERESTARTSYS; 1546 retval = -ERESTARTSYS;
@@ -1549,7 +1549,7 @@ isdn_tty_block_til_ready(struct tty_struct *tty, struct file *filp, modem_info *
1549#endif 1549#endif
1550 break; 1550 break;
1551 } 1551 }
1552 if (!(info->flags & ASYNC_CLOSING) && 1552 if (!(info->port.flags & ASYNC_CLOSING) &&
1553 (do_clocal || (info->msr & UART_MSR_DCD))) { 1553 (do_clocal || (info->msr & UART_MSR_DCD))) {
1554 break; 1554 break;
1555 } 1555 }
@@ -1574,7 +1574,7 @@ isdn_tty_block_til_ready(struct tty_struct *tty, struct file *filp, modem_info *
1574#endif 1574#endif
1575 if (retval) 1575 if (retval)
1576 return retval; 1576 return retval;
1577 info->flags |= ASYNC_NORMAL_ACTIVE; 1577 info->port.flags |= ASYNC_NORMAL_ACTIVE;
1578 return 0; 1578 return 0;
1579} 1579}
1580 1580
@@ -1600,6 +1600,7 @@ isdn_tty_open(struct tty_struct *tty, struct file *filp)
1600 info->count++; 1600 info->count++;
1601 tty->driver_data = info; 1601 tty->driver_data = info;
1602 info->tty = tty; 1602 info->tty = tty;
1603 tty->port = &info->port;
1603 /* 1604 /*
1604 * Start up serial port 1605 * Start up serial port
1605 */ 1606 */
@@ -1664,7 +1665,7 @@ isdn_tty_close(struct tty_struct *tty, struct file *filp)
1664#endif 1665#endif
1665 return; 1666 return;
1666 } 1667 }
1667 info->flags |= ASYNC_CLOSING; 1668 info->port.flags |= ASYNC_CLOSING;
1668 1669
1669 tty->closing = 1; 1670 tty->closing = 1;
1670 /* 1671 /*
@@ -1673,7 +1674,7 @@ isdn_tty_close(struct tty_struct *tty, struct file *filp)
1673 * interrupt driver to stop checking the data ready bit in the 1674 * interrupt driver to stop checking the data ready bit in the
1674 * line status register. 1675 * line status register.
1675 */ 1676 */
1676 if (info->flags & ASYNC_INITIALIZED) { 1677 if (info->port.flags & ASYNC_INITIALIZED) {
1677 tty_wait_until_sent_from_close(tty, 3000); /* 30 seconds timeout */ 1678 tty_wait_until_sent_from_close(tty, 3000); /* 30 seconds timeout */
1678 /* 1679 /*
1679 * Before we drop DTR, make sure the UART transmitter 1680 * Before we drop DTR, make sure the UART transmitter
@@ -1698,7 +1699,7 @@ isdn_tty_close(struct tty_struct *tty, struct file *filp)
1698 msleep_interruptible(500); 1699 msleep_interruptible(500);
1699 wake_up_interruptible(&info->open_wait); 1700 wake_up_interruptible(&info->open_wait);
1700 } 1701 }
1701 info->flags &= ~(ASYNC_NORMAL_ACTIVE | ASYNC_CLOSING); 1702 info->port.flags &= ~(ASYNC_NORMAL_ACTIVE | ASYNC_CLOSING);
1702 wake_up_interruptible(&info->close_wait); 1703 wake_up_interruptible(&info->close_wait);
1703#ifdef ISDN_DEBUG_MODEM_OPEN 1704#ifdef ISDN_DEBUG_MODEM_OPEN
1704 printk(KERN_DEBUG "isdn_tty_close normal exit\n"); 1705 printk(KERN_DEBUG "isdn_tty_close normal exit\n");
@@ -1717,7 +1718,7 @@ isdn_tty_hangup(struct tty_struct *tty)
1717 return; 1718 return;
1718 isdn_tty_shutdown(info); 1719 isdn_tty_shutdown(info);
1719 info->count = 0; 1720 info->count = 0;
1720 info->flags &= ~ASYNC_NORMAL_ACTIVE; 1721 info->port.flags &= ~ASYNC_NORMAL_ACTIVE;
1721 info->tty = NULL; 1722 info->tty = NULL;
1722 wake_up_interruptible(&info->open_wait); 1723 wake_up_interruptible(&info->open_wait);
1723} 1724}
@@ -1881,6 +1882,7 @@ isdn_tty_modem_init(void)
1881 goto err_unregister; 1882 goto err_unregister;
1882 } 1883 }
1883#endif 1884#endif
1885 tty_port_init(&info->port);
1884 spin_lock_init(&info->readlock); 1886 spin_lock_init(&info->readlock);
1885 sprintf(info->last_cause, "0000"); 1887 sprintf(info->last_cause, "0000");
1886 sprintf(info->last_num, "none"); 1888 sprintf(info->last_num, "none");
@@ -2055,12 +2057,12 @@ isdn_tty_find_icall(int di, int ch, setup_parm *setup)
2055#ifdef ISDN_DEBUG_MODEM_ICALL 2057#ifdef ISDN_DEBUG_MODEM_ICALL
2056 printk(KERN_DEBUG "m_fi: match1 wret=%d\n", wret); 2058 printk(KERN_DEBUG "m_fi: match1 wret=%d\n", wret);
2057 printk(KERN_DEBUG "m_fi: idx=%d flags=%08lx drv=%d ch=%d usg=%d\n", idx, 2059 printk(KERN_DEBUG "m_fi: idx=%d flags=%08lx drv=%d ch=%d usg=%d\n", idx,
2058 info->flags, info->isdn_driver, info->isdn_channel, 2060 info->port.flags, info->isdn_driver,
2059 dev->usage[idx]); 2061 info->isdn_channel, dev->usage[idx]);
2060#endif 2062#endif
2061 if ( 2063 if (
2062#ifndef FIX_FILE_TRANSFER 2064#ifndef FIX_FILE_TRANSFER
2063 (info->flags & ASYNC_NORMAL_ACTIVE) && 2065 (info->port.flags & ASYNC_NORMAL_ACTIVE) &&
2064#endif 2066#endif
2065 (info->isdn_driver == -1) && 2067 (info->isdn_driver == -1) &&
2066 (info->isdn_channel == -1) && 2068 (info->isdn_channel == -1) &&
@@ -2099,7 +2101,7 @@ isdn_tty_find_icall(int di, int ch, setup_parm *setup)
2099 return (wret == 2) ? 3 : 0; 2101 return (wret == 2) ? 3 : 0;
2100} 2102}
2101 2103
2102#define TTY_IS_ACTIVE(info) (info->flags & ASYNC_NORMAL_ACTIVE) 2104#define TTY_IS_ACTIVE(info) (info->port.flags & ASYNC_NORMAL_ACTIVE)
2103 2105
2104int 2106int
2105isdn_tty_stat_callback(int i, isdn_ctrl *c) 2107isdn_tty_stat_callback(int i, isdn_ctrl *c)
@@ -2318,7 +2320,7 @@ isdn_tty_at_cout(char *msg, modem_info *info)
2318 2320
2319 spin_lock_irqsave(&info->readlock, flags); 2321 spin_lock_irqsave(&info->readlock, flags);
2320 tty = info->tty; 2322 tty = info->tty;
2321 if ((info->flags & ASYNC_CLOSING) || (!tty)) { 2323 if ((info->port.flags & ASYNC_CLOSING) || (!tty)) {
2322 spin_unlock_irqrestore(&info->readlock, flags); 2324 spin_unlock_irqrestore(&info->readlock, flags);
2323 return; 2325 return;
2324 } 2326 }
@@ -2468,13 +2470,13 @@ isdn_tty_modem_result(int code, modem_info *info)
2468 case RESULT_NO_CARRIER: 2470 case RESULT_NO_CARRIER:
2469#ifdef ISDN_DEBUG_MODEM_HUP 2471#ifdef ISDN_DEBUG_MODEM_HUP
2470 printk(KERN_DEBUG "modem_result: NO CARRIER %d %d\n", 2472 printk(KERN_DEBUG "modem_result: NO CARRIER %d %d\n",
2471 (info->flags & ASYNC_CLOSING), 2473 (info->port.flags & ASYNC_CLOSING),
2472 (!info->tty)); 2474 (!info->tty));
2473#endif 2475#endif
2474 m->mdmreg[REG_RINGCNT] = 0; 2476 m->mdmreg[REG_RINGCNT] = 0;
2475 del_timer(&info->nc_timer); 2477 del_timer(&info->nc_timer);
2476 info->ncarrier = 0; 2478 info->ncarrier = 0;
2477 if ((info->flags & ASYNC_CLOSING) || (!info->tty)) 2479 if ((info->port.flags & ASYNC_CLOSING) || (!info->tty))
2478 return; 2480 return;
2479 2481
2480#ifdef CONFIG_ISDN_AUDIO 2482#ifdef CONFIG_ISDN_AUDIO
@@ -2607,10 +2609,10 @@ isdn_tty_modem_result(int code, modem_info *info)
2607 } 2609 }
2608 } 2610 }
2609 if (code == RESULT_NO_CARRIER) { 2611 if (code == RESULT_NO_CARRIER) {
2610 if ((info->flags & ASYNC_CLOSING) || (!info->tty)) 2612 if ((info->port.flags & ASYNC_CLOSING) || (!info->tty))
2611 return; 2613 return;
2612 2614
2613 if (info->flags & ASYNC_CHECK_CD) 2615 if (info->port.flags & ASYNC_CHECK_CD)
2614 tty_hangup(info->tty); 2616 tty_hangup(info->tty);
2615 } 2617 }
2616} 2618}
diff --git a/include/linux/isdn.h b/include/linux/isdn.h
index 63af3208004f..bb710414f275 100644
--- a/include/linux/isdn.h
+++ b/include/linux/isdn.h
@@ -15,6 +15,7 @@
15#define __ISDN_H__ 15#define __ISDN_H__
16 16
17#include <linux/ioctl.h> 17#include <linux/ioctl.h>
18#include <linux/tty.h>
18 19
19#define ISDN_MAX_DRIVERS 32 20#define ISDN_MAX_DRIVERS 32
20#define ISDN_MAX_CHANNELS 64 21#define ISDN_MAX_CHANNELS 64
@@ -435,7 +436,7 @@ typedef struct atemu {
435/* Private data (similar to async_struct in <linux/serial.h>) */ 436/* Private data (similar to async_struct in <linux/serial.h>) */
436typedef struct modem_info { 437typedef struct modem_info {
437 int magic; 438 int magic;
438 int flags; /* defined in tty.h */ 439 struct tty_port port;
439 int x_char; /* xon/xoff character */ 440 int x_char; /* xon/xoff character */
440 int mcr; /* Modem control register */ 441 int mcr; /* Modem control register */
441 int msr; /* Modem status register */ 442 int msr; /* Modem status register */