patch-2.2.14 linux/drivers/isdn/isdn_tty.c
Next file: linux/drivers/isdn/isdn_v110.c
Previous file: linux/drivers/isdn/isdn_ppp.c
Back to the patch index
Back to the overall index
- Lines: 204
- Date:
Tue Jan 4 10:12:17 2000
- Orig file:
v2.2.13/linux/drivers/isdn/isdn_tty.c
- Orig date:
Tue Jan 4 11:10:35 2000
diff -u --recursive --new-file v2.2.13/linux/drivers/isdn/isdn_tty.c linux/drivers/isdn/isdn_tty.c
@@ -1,4 +1,4 @@
-/* $Id: isdn_tty.c,v 1.74 1999/09/04 06:20:04 keil Exp $
+/* $Id: isdn_tty.c,v 1.80 1999/11/07 13:34:30 armin Exp $
* Linux ISDN subsystem, tty functions and AT-command emulator (linklevel).
*
@@ -20,6 +20,27 @@
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*
* $Log: isdn_tty.c,v $
+ * Revision 1.80 1999/11/07 13:34:30 armin
+ * Fixed AT command line editor
+ *
+ * Revision 1.79 1999/10/29 18:35:08 armin
+ * Check number len in isdn_get_msnstr() to avoid buffer overflow.
+ *
+ * Revision 1.78 1999/10/28 23:03:51 armin
+ * Bugfix: now freeing channel on modem_hup() even when
+ * usage on ttyI has changed and error-report for
+ * AT-commands on wrong channel-state.
+ *
+ * Revision 1.77 1999/10/26 21:13:14 armin
+ * using define for checking phone number len in isdn_tty_getdial()
+ *
+ * Revision 1.76 1999/10/11 22:16:26 keil
+ * Suspend/Resume is possible without explicit ID too
+ *
+ * Revision 1.75 1999/10/08 18:59:32 armin
+ * Bugfix of too small MSN buffer and checking phone number
+ * in isdn_tty_getdial()
+ *
* Revision 1.74 1999/09/04 06:20:04 keil
* Changes from kernel set_current_state()
*
@@ -351,7 +372,7 @@
static int si2bit[8] =
{4, 1, 4, 4, 4, 4, 4, 4};
-char *isdn_tty_revision = "$Revision: 1.74 $";
+char *isdn_tty_revision = "$Revision: 1.80 $";
/* isdn_tty_try_read() is called from within isdn_tty_rcv_skb()
@@ -1017,7 +1038,6 @@
isdn_tty_modem_hup(modem_info * info, int local)
{
isdn_ctrl cmd;
- int usage;
if (!info)
return;
@@ -1071,10 +1091,7 @@
}
isdn_all_eaz(info->isdn_driver, info->isdn_channel);
info->emu.mdmreg[REG_RINGCNT] = 0;
- usage = isdn_calc_usage(info->emu.mdmreg[REG_SI1I],
- info->emu.mdmreg[REG_L2PROT]);
- isdn_free_channel(info->isdn_driver, info->isdn_channel,
- usage);
+ isdn_free_channel(info->isdn_driver, info->isdn_channel, 0);
}
info->isdn_driver = -1;
info->isdn_channel = -1;
@@ -1111,8 +1128,8 @@
printk(KERN_DEBUG "Msusp ttyI%d\n", info->line);
#endif
l = strlen(id);
- if ((info->isdn_driver >= 0) && l) {
- cmd.parm.cmsg.Length = l+17;
+ if ((info->isdn_driver >= 0)) {
+ cmd.parm.cmsg.Length = l+18;
cmd.parm.cmsg.Command = CAPI_FACILITY;
cmd.parm.cmsg.Subcommand = CAPI_REQ;
cmd.parm.cmsg.adr.Controller = info->isdn_driver + 1;
@@ -1150,10 +1167,6 @@
int l;
l = strlen(id);
- if (!l) {
- isdn_tty_modem_result(4, info);
- return;
- }
for (j = 7; j >= 0; j--)
if (m->mdmreg[REG_SI1] & (1 << j)) {
si = bit2si[j];
@@ -1207,7 +1220,7 @@
isdn_command(&cmd);
cmd.driver = info->isdn_driver;
cmd.arg = info->isdn_channel;
- cmd.parm.cmsg.Length = l+17;
+ cmd.parm.cmsg.Length = l+18;
cmd.parm.cmsg.Command = CAPI_FACILITY;
cmd.parm.cmsg.Subcommand = CAPI_REQ;
cmd.parm.cmsg.adr.Controller = info->isdn_driver + 1;
@@ -3091,9 +3104,12 @@
static void
isdn_tty_get_msnstr(char *n, char **p)
{
- while ((*p[0] >= '0' && *p[0] <= '9') ||
+ int limit = ISDN_MSNLEN - 1;
+
+ while (((*p[0] >= '0' && *p[0] <= '9') ||
/* Why a comma ??? */
- (*p[0] == ','))
+ (*p[0] == ',')) &&
+ (limit--))
*n++ = *p[0]++;
*n = '\0';
}
@@ -3105,16 +3121,18 @@
isdn_tty_getdial(char *p, char *q,int cnt)
{
int first = 1;
- int limit=39; /* MUST match the size in isdn_tty_parse to avoid
- buffer overflow */
+ int limit = ISDN_MSNLEN - 1; /* MUST match the size of interface var to avoid
+ buffer overflow */
while (strchr(" 0123456789,#.*WPTS-", *p) && *p && --cnt>0) {
if ((*p >= '0' && *p <= '9') || ((*p == 'S') && first) ||
- (*p == '*') || (*p == '#'))
+ (*p == '*') || (*p == '#')) {
*q++ = *p;
- p++;
- if(!--limit)
+ limit--;
+ }
+ if(!limit)
break;
+ p++;
first = 0;
}
*q = 0;
@@ -3258,6 +3276,8 @@
case 'F':
/* &F -Set Factory-Defaults */
p[0]++;
+ if (info->msr & UART_MSR_DCD)
+ PARSE_ERROR1;
isdn_tty_reset_profile(m);
isdn_tty_modem_reset_regs(info, 1);
break;
@@ -3909,6 +3929,12 @@
break;
case 'D':
/* D - Dial */
+ if (info->msr & UART_MSR_DCD)
+ PARSE_ERROR;
+ if (info->msr & UART_MSR_RI) {
+ isdn_tty_modem_result(3, info);
+ return;
+ }
isdn_tty_getdial(++p, ds, sizeof ds);
p += strlen(p);
if (!strlen(m->msn))
@@ -4103,7 +4129,7 @@
c = *p;
total++;
if (c == m->mdmreg[REG_CR] || c == m->mdmreg[REG_LF]) {
- /* Separator (CR oder LF) */
+ /* Separator (CR or LF) */
m->mdmcmd[m->mdmcmdl] = 0;
if (m->mdmreg[REG_ECHO] & BIT_ECHO) {
eb[0] = c;
@@ -4116,7 +4142,7 @@
continue;
}
if (c == m->mdmreg[REG_BS] && m->mdmreg[REG_BS] < 128) {
- /* Backspace-Funktion */
+ /* Backspace-Function */
if ((m->mdmcmdl > 2) || (!m->mdmcmdl)) {
if (m->mdmcmdl)
m->mdmcmdl--;
@@ -4134,18 +4160,24 @@
if (m->mdmcmdl < 255) {
c = my_toupper(c);
switch (m->mdmcmdl) {
- case 0:
- if (c == 'A')
- m->mdmcmd[m->mdmcmdl] = c;
- break;
case 1:
- if (c == 'T')
+ if (c == 'T') {
+ m->mdmcmd[m->mdmcmdl] = c;
+ m->mdmcmd[++m->mdmcmdl] = 0;
+ break;
+ } else
+ m->mdmcmdl = 0;
+ /* Fall through, check for 'A' */
+ case 0:
+ if (c == 'A') {
m->mdmcmd[m->mdmcmdl] = c;
+ m->mdmcmd[++m->mdmcmdl] = 0;
+ }
break;
default:
m->mdmcmd[m->mdmcmdl] = c;
+ m->mdmcmd[++m->mdmcmdl] = 0;
}
- m->mdmcmd[++m->mdmcmdl] = 0;
}
}
}
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)