aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/isdn/i4l/isdn_net.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/isdn/i4l/isdn_net.c')
-rw-r--r--drivers/isdn/i4l/isdn_net.c144
1 files changed, 79 insertions, 65 deletions
diff --git a/drivers/isdn/i4l/isdn_net.c b/drivers/isdn/i4l/isdn_net.c
index 7c9cb7e19f2e..71ec2a8aab2a 100644
--- a/drivers/isdn/i4l/isdn_net.c
+++ b/drivers/isdn/i4l/isdn_net.c
@@ -328,7 +328,7 @@ isdn_net_autohup(void)
328 l->cps = (l->transcount * HZ) / (jiffies - last_jiffies); 328 l->cps = (l->transcount * HZ) / (jiffies - last_jiffies);
329 l->transcount = 0; 329 l->transcount = 0;
330 if (dev->net_verbose > 3) 330 if (dev->net_verbose > 3)
331 printk(KERN_DEBUG "%s: %d bogocps\n", l->name, l->cps); 331 printk(KERN_DEBUG "%s: %d bogocps\n", p->dev->name, l->cps);
332 if ((l->flags & ISDN_NET_CONNECTED) && (!l->dialstate)) { 332 if ((l->flags & ISDN_NET_CONNECTED) && (!l->dialstate)) {
333 anymore = 1; 333 anymore = 1;
334 l->huptimer++; 334 l->huptimer++;
@@ -350,12 +350,12 @@ isdn_net_autohup(void)
350 if (l->hupflags & ISDN_CHARGEHUP) { 350 if (l->hupflags & ISDN_CHARGEHUP) {
351 if (l->hupflags & ISDN_WAITCHARGE) { 351 if (l->hupflags & ISDN_WAITCHARGE) {
352 printk(KERN_DEBUG "isdn_net: Hupflags of %s are %X\n", 352 printk(KERN_DEBUG "isdn_net: Hupflags of %s are %X\n",
353 l->name, l->hupflags); 353 p->dev->name, l->hupflags);
354 isdn_net_hangup(p->dev); 354 isdn_net_hangup(p->dev);
355 } else if (time_after(jiffies, l->chargetime + l->chargeint)) { 355 } else if (time_after(jiffies, l->chargetime + l->chargeint)) {
356 printk(KERN_DEBUG 356 printk(KERN_DEBUG
357 "isdn_net: %s: chtime = %lu, chint = %d\n", 357 "isdn_net: %s: chtime = %lu, chint = %d\n",
358 l->name, l->chargetime, l->chargeint); 358 p->dev->name, l->chargetime, l->chargeint);
359 isdn_net_hangup(p->dev); 359 isdn_net_hangup(p->dev);
360 } 360 }
361 } else 361 } else
@@ -442,8 +442,8 @@ isdn_net_stat_callback(int idx, isdn_ctrl *c)
442#endif 442#endif
443 isdn_net_lp_disconnected(lp); 443 isdn_net_lp_disconnected(lp);
444 isdn_all_eaz(lp->isdn_device, lp->isdn_channel); 444 isdn_all_eaz(lp->isdn_device, lp->isdn_channel);
445 printk(KERN_INFO "%s: remote hangup\n", lp->name); 445 printk(KERN_INFO "%s: remote hangup\n", p->dev->name);
446 printk(KERN_INFO "%s: Chargesum is %d\n", lp->name, 446 printk(KERN_INFO "%s: Chargesum is %d\n", p->dev->name,
447 lp->charge); 447 lp->charge);
448 isdn_net_unbind_channel(lp); 448 isdn_net_unbind_channel(lp);
449 return 1; 449 return 1;
@@ -487,7 +487,7 @@ isdn_net_stat_callback(int idx, isdn_ctrl *c)
487 isdn_net_add_to_bundle(nd, lp); 487 isdn_net_add_to_bundle(nd, lp);
488 } 488 }
489 } 489 }
490 printk(KERN_INFO "isdn_net: %s connected\n", lp->name); 490 printk(KERN_INFO "isdn_net: %s connected\n", p->dev->name);
491 /* If first Chargeinfo comes before B-Channel connect, 491 /* If first Chargeinfo comes before B-Channel connect,
492 * we correct the timestamp here. 492 * we correct the timestamp here.
493 */ 493 */
@@ -534,7 +534,7 @@ isdn_net_stat_callback(int idx, isdn_ctrl *c)
534 lp->hupflags |= ISDN_HAVECHARGE; 534 lp->hupflags |= ISDN_HAVECHARGE;
535 lp->chargetime = jiffies; 535 lp->chargetime = jiffies;
536 printk(KERN_DEBUG "isdn_net: Got CINF chargetime of %s now %lu\n", 536 printk(KERN_DEBUG "isdn_net: Got CINF chargetime of %s now %lu\n",
537 lp->name, lp->chargetime); 537 p->dev->name, lp->chargetime);
538 return 1; 538 return 1;
539 } 539 }
540 } 540 }
@@ -565,7 +565,7 @@ isdn_net_dial(void)
565 565
566#ifdef ISDN_DEBUG_NET_DIAL 566#ifdef ISDN_DEBUG_NET_DIAL
567 if (lp->dialstate) 567 if (lp->dialstate)
568 printk(KERN_DEBUG "%s: dialstate=%d\n", lp->name, lp->dialstate); 568 printk(KERN_DEBUG "%s: dialstate=%d\n", p->dev->name, lp->dialstate);
569#endif 569#endif
570 switch (lp->dialstate) { 570 switch (lp->dialstate) {
571 case 0: 571 case 0:
@@ -578,7 +578,7 @@ isdn_net_dial(void)
578 lp->dial = lp->phone[1]; 578 lp->dial = lp->phone[1];
579 if (!lp->dial) { 579 if (!lp->dial) {
580 printk(KERN_WARNING "%s: phone number deleted?\n", 580 printk(KERN_WARNING "%s: phone number deleted?\n",
581 lp->name); 581 p->dev->name);
582 isdn_net_hangup(p->dev); 582 isdn_net_hangup(p->dev);
583 break; 583 break;
584 } 584 }
@@ -632,13 +632,13 @@ isdn_net_dial(void)
632 cmd.arg = lp->isdn_channel; 632 cmd.arg = lp->isdn_channel;
633 if (!lp->dial) { 633 if (!lp->dial) {
634 printk(KERN_WARNING "%s: phone number deleted?\n", 634 printk(KERN_WARNING "%s: phone number deleted?\n",
635 lp->name); 635 p->dev->name);
636 isdn_net_hangup(p->dev); 636 isdn_net_hangup(p->dev);
637 break; 637 break;
638 } 638 }
639 if (!strncmp(lp->dial->num, "LEASED", strlen("LEASED"))) { 639 if (!strncmp(lp->dial->num, "LEASED", strlen("LEASED"))) {
640 lp->dialstate = 4; 640 lp->dialstate = 4;
641 printk(KERN_INFO "%s: Open leased line ...\n", lp->name); 641 printk(KERN_INFO "%s: Open leased line ...\n", p->dev->name);
642 } else { 642 } else {
643 if(lp->dialtimeout > 0) 643 if(lp->dialtimeout > 0)
644 if (time_after(jiffies, lp->dialstarted + lp->dialtimeout)) { 644 if (time_after(jiffies, lp->dialstarted + lp->dialtimeout)) {
@@ -688,7 +688,7 @@ isdn_net_dial(void)
688 dev->usage[i] |= ISDN_USAGE_OUTGOING; 688 dev->usage[i] |= ISDN_USAGE_OUTGOING;
689 isdn_info_update(); 689 isdn_info_update();
690 } 690 }
691 printk(KERN_INFO "%s: dialing %d %s... %s\n", lp->name, 691 printk(KERN_INFO "%s: dialing %d %s... %s\n", p->dev->name,
692 lp->dialretry, cmd.parm.setup.phone, 692 lp->dialretry, cmd.parm.setup.phone,
693 (cmd.parm.setup.si1 == 1) ? "DOV" : ""); 693 (cmd.parm.setup.si1 == 1) ? "DOV" : "");
694 lp->dtimer = 0; 694 lp->dtimer = 0;
@@ -797,7 +797,7 @@ isdn_net_dial(void)
797 */ 797 */
798 if (lp->dtimer++ > lp->cbdelay) 798 if (lp->dtimer++ > lp->cbdelay)
799 { 799 {
800 printk(KERN_INFO "%s: hangup waiting for callback ...\n", lp->name); 800 printk(KERN_INFO "%s: hangup waiting for callback ...\n", p->dev->name);
801 lp->dtimer = 0; 801 lp->dtimer = 0;
802 lp->dialstate = 4; 802 lp->dialstate = 4;
803 cmd.driver = lp->isdn_device; 803 cmd.driver = lp->isdn_device;
@@ -810,7 +810,7 @@ isdn_net_dial(void)
810 break; 810 break;
811 default: 811 default:
812 printk(KERN_WARNING "isdn_net: Illegal dialstate %d for device %s\n", 812 printk(KERN_WARNING "isdn_net: Illegal dialstate %d for device %s\n",
813 lp->dialstate, lp->name); 813 lp->dialstate, p->dev->name);
814 } 814 }
815 p = (isdn_net_dev *) p->next; 815 p = (isdn_net_dev *) p->next;
816 } 816 }
@@ -836,11 +836,11 @@ isdn_net_hangup(struct net_device *d)
836 if (slp->flags & ISDN_NET_CONNECTED) { 836 if (slp->flags & ISDN_NET_CONNECTED) {
837 printk(KERN_INFO 837 printk(KERN_INFO
838 "isdn_net: hang up slave %s before %s\n", 838 "isdn_net: hang up slave %s before %s\n",
839 slp->name, lp->name); 839 lp->slave->name, d->name);
840 isdn_net_hangup(lp->slave); 840 isdn_net_hangup(lp->slave);
841 } 841 }
842 } 842 }
843 printk(KERN_INFO "isdn_net: local hangup %s\n", lp->name); 843 printk(KERN_INFO "isdn_net: local hangup %s\n", d->name);
844#ifdef CONFIG_ISDN_PPP 844#ifdef CONFIG_ISDN_PPP
845 if (lp->p_encap == ISDN_NET_ENCAP_SYNCPPP) 845 if (lp->p_encap == ISDN_NET_ENCAP_SYNCPPP)
846 isdn_ppp_free(lp); 846 isdn_ppp_free(lp);
@@ -858,7 +858,7 @@ isdn_net_hangup(struct net_device *d)
858 cmd.command = ISDN_CMD_HANGUP; 858 cmd.command = ISDN_CMD_HANGUP;
859 cmd.arg = lp->isdn_channel; 859 cmd.arg = lp->isdn_channel;
860 isdn_command(&cmd); 860 isdn_command(&cmd);
861 printk(KERN_INFO "%s: Chargesum is %d\n", lp->name, lp->charge); 861 printk(KERN_INFO "%s: Chargesum is %d\n", d->name, lp->charge);
862 isdn_all_eaz(lp->isdn_device, lp->isdn_channel); 862 isdn_all_eaz(lp->isdn_device, lp->isdn_channel);
863 } 863 }
864 isdn_net_unbind_channel(lp); 864 isdn_net_unbind_channel(lp);
@@ -885,7 +885,7 @@ isdn_net_log_skb(struct sk_buff * skb, isdn_net_local * lp)
885 /* fall back to old isdn_net_log_packet method() */ 885 /* fall back to old isdn_net_log_packet method() */
886 char * buf = skb->data; 886 char * buf = skb->data;
887 887
888 printk(KERN_DEBUG "isdn_net: protocol %04x is buggy, dev %s\n", skb->protocol, lp->name); 888 printk(KERN_DEBUG "isdn_net: protocol %04x is buggy, dev %s\n", skb->protocol, lp->netdev->dev->name);
889 p = buf; 889 p = buf;
890 proto = ETH_P_IP; 890 proto = ETH_P_IP;
891 switch (lp->p_encap) { 891 switch (lp->p_encap) {
@@ -1023,7 +1023,7 @@ void isdn_net_writebuf_skb(isdn_net_local *lp, struct sk_buff *skb)
1023 ret = isdn_writebuf_skb_stub(lp->isdn_device, lp->isdn_channel, 1, skb); 1023 ret = isdn_writebuf_skb_stub(lp->isdn_device, lp->isdn_channel, 1, skb);
1024 if (ret != len) { 1024 if (ret != len) {
1025 /* we should never get here */ 1025 /* we should never get here */
1026 printk(KERN_WARNING "%s: HL driver queue full\n", lp->name); 1026 printk(KERN_WARNING "%s: HL driver queue full\n", lp->netdev->dev->name);
1027 goto error; 1027 goto error;
1028 } 1028 }
1029 1029
@@ -1461,7 +1461,7 @@ isdn_ciscohdlck_dev_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
1461 mod_timer(&lp->cisco_timer, expires); 1461 mod_timer(&lp->cisco_timer, expires);
1462 printk(KERN_INFO "%s: Keepalive period set " 1462 printk(KERN_INFO "%s: Keepalive period set "
1463 "to %d seconds.\n", 1463 "to %d seconds.\n",
1464 lp->name, lp->cisco_keepalive_period); 1464 dev->name, lp->cisco_keepalive_period);
1465 } 1465 }
1466 break; 1466 break;
1467 1467
@@ -1512,7 +1512,7 @@ isdn_net_ciscohdlck_slarp_send_keepalive(unsigned long data)
1512 lp->cisco_line_state = 0; 1512 lp->cisco_line_state = 0;
1513 printk (KERN_WARNING 1513 printk (KERN_WARNING
1514 "UPDOWN: Line protocol on Interface %s," 1514 "UPDOWN: Line protocol on Interface %s,"
1515 " changed state to down\n", lp->name); 1515 " changed state to down\n", lp->netdev->dev->name);
1516 /* should stop routing higher-level data accross */ 1516 /* should stop routing higher-level data accross */
1517 } else if ((!lp->cisco_line_state) && 1517 } else if ((!lp->cisco_line_state) &&
1518 (myseq_diff >= 0) && (myseq_diff <= 2)) { 1518 (myseq_diff >= 0) && (myseq_diff <= 2)) {
@@ -1520,14 +1520,14 @@ isdn_net_ciscohdlck_slarp_send_keepalive(unsigned long data)
1520 lp->cisco_line_state = 1; 1520 lp->cisco_line_state = 1;
1521 printk (KERN_WARNING 1521 printk (KERN_WARNING
1522 "UPDOWN: Line protocol on Interface %s," 1522 "UPDOWN: Line protocol on Interface %s,"
1523 " changed state to up\n", lp->name); 1523 " changed state to up\n", lp->netdev->dev->name);
1524 /* restart routing higher-level data accross */ 1524 /* restart routing higher-level data accross */
1525 } 1525 }
1526 1526
1527 if (lp->cisco_debserint) 1527 if (lp->cisco_debserint)
1528 printk (KERN_DEBUG "%s: HDLC " 1528 printk (KERN_DEBUG "%s: HDLC "
1529 "myseq %lu, mineseen %lu%c, yourseen %lu, %s\n", 1529 "myseq %lu, mineseen %lu%c, yourseen %lu, %s\n",
1530 lp->name, last_cisco_myseq, lp->cisco_mineseen, 1530 lp->netdev->dev->name, last_cisco_myseq, lp->cisco_mineseen,
1531 ((last_cisco_myseq == lp->cisco_mineseen) ? '*' : 040), 1531 ((last_cisco_myseq == lp->cisco_mineseen) ? '*' : 040),
1532 lp->cisco_yourseq, 1532 lp->cisco_yourseq,
1533 ((lp->cisco_line_state) ? "line up" : "line down")); 1533 ((lp->cisco_line_state) ? "line up" : "line down"));
@@ -1682,7 +1682,7 @@ isdn_net_ciscohdlck_slarp_in(isdn_net_local *lp, struct sk_buff *skb)
1682 "remote ip: %d.%d.%d.%d, " 1682 "remote ip: %d.%d.%d.%d, "
1683 "local ip: %d.%d.%d.%d " 1683 "local ip: %d.%d.%d.%d "
1684 "mask: %d.%d.%d.%d\n", 1684 "mask: %d.%d.%d.%d\n",
1685 lp->name, 1685 lp->netdev->dev->name,
1686 HIPQUAD(addr), 1686 HIPQUAD(addr),
1687 HIPQUAD(local), 1687 HIPQUAD(local),
1688 HIPQUAD(mask)); 1688 HIPQUAD(mask));
@@ -1690,7 +1690,7 @@ isdn_net_ciscohdlck_slarp_in(isdn_net_local *lp, struct sk_buff *skb)
1690 slarp_reply_out: 1690 slarp_reply_out:
1691 printk(KERN_INFO "%s: got invalid slarp " 1691 printk(KERN_INFO "%s: got invalid slarp "
1692 "reply (%d.%d.%d.%d/%d.%d.%d.%d) " 1692 "reply (%d.%d.%d.%d/%d.%d.%d.%d) "
1693 "- ignored\n", lp->name, 1693 "- ignored\n", lp->netdev->dev->name,
1694 HIPQUAD(addr), HIPQUAD(mask)); 1694 HIPQUAD(addr), HIPQUAD(mask));
1695 break; 1695 break;
1696 case CISCO_SLARP_KEEPALIVE: 1696 case CISCO_SLARP_KEEPALIVE:
@@ -1701,7 +1701,8 @@ isdn_net_ciscohdlck_slarp_in(isdn_net_local *lp, struct sk_buff *skb)
1701 lp->cisco_last_slarp_in) { 1701 lp->cisco_last_slarp_in) {
1702 printk(KERN_DEBUG "%s: Keepalive period mismatch - " 1702 printk(KERN_DEBUG "%s: Keepalive period mismatch - "
1703 "is %d but should be %d.\n", 1703 "is %d but should be %d.\n",
1704 lp->name, period, lp->cisco_keepalive_period); 1704 lp->netdev->dev->name, period,
1705 lp->cisco_keepalive_period);
1705 } 1706 }
1706 lp->cisco_last_slarp_in = jiffies; 1707 lp->cisco_last_slarp_in = jiffies;
1707 p += get_u32(p, &my_seq); 1708 p += get_u32(p, &my_seq);
@@ -1732,12 +1733,12 @@ isdn_net_ciscohdlck_receive(isdn_net_local *lp, struct sk_buff *skb)
1732 1733
1733 if (addr != CISCO_ADDR_UNICAST && addr != CISCO_ADDR_BROADCAST) { 1734 if (addr != CISCO_ADDR_UNICAST && addr != CISCO_ADDR_BROADCAST) {
1734 printk(KERN_WARNING "%s: Unknown Cisco addr 0x%02x\n", 1735 printk(KERN_WARNING "%s: Unknown Cisco addr 0x%02x\n",
1735 lp->name, addr); 1736 lp->netdev->dev->name, addr);
1736 goto out_free; 1737 goto out_free;
1737 } 1738 }
1738 if (ctrl != CISCO_CTRL) { 1739 if (ctrl != CISCO_CTRL) {
1739 printk(KERN_WARNING "%s: Unknown Cisco ctrl 0x%02x\n", 1740 printk(KERN_WARNING "%s: Unknown Cisco ctrl 0x%02x\n",
1740 lp->name, ctrl); 1741 lp->netdev->dev->name, ctrl);
1741 goto out_free; 1742 goto out_free;
1742 } 1743 }
1743 1744
@@ -1748,7 +1749,8 @@ isdn_net_ciscohdlck_receive(isdn_net_local *lp, struct sk_buff *skb)
1748 case CISCO_TYPE_CDP: 1749 case CISCO_TYPE_CDP:
1749 if (lp->cisco_debserint) 1750 if (lp->cisco_debserint)
1750 printk(KERN_DEBUG "%s: Received CDP packet. use " 1751 printk(KERN_DEBUG "%s: Received CDP packet. use "
1751 "\"no cdp enable\" on cisco.\n", lp->name); 1752 "\"no cdp enable\" on cisco.\n",
1753 lp->netdev->dev->name);
1752 goto out_free; 1754 goto out_free;
1753 default: 1755 default:
1754 /* no special cisco protocol */ 1756 /* no special cisco protocol */
@@ -1843,7 +1845,7 @@ isdn_net_receive(struct net_device *ndev, struct sk_buff *skb)
1843 }; 1845 };
1844#endif /* CONFIG_ISDN_X25 */ 1846#endif /* CONFIG_ISDN_X25 */
1845 printk(KERN_WARNING "%s: unknown encapsulation, dropping\n", 1847 printk(KERN_WARNING "%s: unknown encapsulation, dropping\n",
1846 lp->name); 1848 lp->netdev->dev->name);
1847 kfree_skb(skb); 1849 kfree_skb(skb);
1848 return; 1850 return;
1849 } 1851 }
@@ -2174,7 +2176,7 @@ isdn_net_find_icall(int di, int ch, int idx, setup_parm *setup)
2174 wret = matchret; 2176 wret = matchret;
2175#ifdef ISDN_DEBUG_NET_ICALL 2177#ifdef ISDN_DEBUG_NET_ICALL
2176 printk(KERN_DEBUG "n_fi: if='%s', l.msn=%s, l.flags=%d, l.dstate=%d\n", 2178 printk(KERN_DEBUG "n_fi: if='%s', l.msn=%s, l.flags=%d, l.dstate=%d\n",
2177 lp->name, lp->msn, lp->flags, lp->dialstate); 2179 p->dev->name, lp->msn, lp->flags, lp->dialstate);
2178#endif 2180#endif
2179 if ((!matchret) && /* EAZ is matching */ 2181 if ((!matchret) && /* EAZ is matching */
2180 (((!(lp->flags & ISDN_NET_CONNECTED)) && /* but not connected */ 2182 (((!(lp->flags & ISDN_NET_CONNECTED)) && /* but not connected */
@@ -2277,7 +2279,7 @@ isdn_net_find_icall(int di, int ch, int idx, setup_parm *setup)
2277 * */ 2279 * */
2278 if (ISDN_NET_DIALMODE(*lp) == ISDN_NET_DM_OFF) { 2280 if (ISDN_NET_DIALMODE(*lp) == ISDN_NET_DM_OFF) {
2279 printk(KERN_INFO "incoming call, interface %s `stopped' -> rejected\n", 2281 printk(KERN_INFO "incoming call, interface %s `stopped' -> rejected\n",
2280 lp->name); 2282 p->dev->name);
2281 return 3; 2283 return 3;
2282 } 2284 }
2283 /* 2285 /*
@@ -2286,7 +2288,7 @@ isdn_net_find_icall(int di, int ch, int idx, setup_parm *setup)
2286 */ 2288 */
2287 if (!isdn_net_device_started(p)) { 2289 if (!isdn_net_device_started(p)) {
2288 printk(KERN_INFO "%s: incoming call, interface down -> rejected\n", 2290 printk(KERN_INFO "%s: incoming call, interface down -> rejected\n",
2289 lp->name); 2291 p->dev->name);
2290 return 3; 2292 return 3;
2291 } 2293 }
2292 /* Interface is up, now see if it's a slave. If so, see if 2294 /* Interface is up, now see if it's a slave. If so, see if
@@ -2294,8 +2296,8 @@ isdn_net_find_icall(int di, int ch, int idx, setup_parm *setup)
2294 */ 2296 */
2295 if (lp->master) { 2297 if (lp->master) {
2296 isdn_net_local *mlp = (isdn_net_local *) lp->master->priv; 2298 isdn_net_local *mlp = (isdn_net_local *) lp->master->priv;
2297 printk(KERN_DEBUG "ICALLslv: %s\n", lp->name); 2299 printk(KERN_DEBUG "ICALLslv: %s\n", p->dev->name);
2298 printk(KERN_DEBUG "master=%s\n", mlp->name); 2300 printk(KERN_DEBUG "master=%s\n", lp->master->name);
2299 if (mlp->flags & ISDN_NET_CONNECTED) { 2301 if (mlp->flags & ISDN_NET_CONNECTED) {
2300 printk(KERN_DEBUG "master online\n"); 2302 printk(KERN_DEBUG "master online\n");
2301 /* Master is online, find parent-slave (master if first slave) */ 2303 /* Master is online, find parent-slave (master if first slave) */
@@ -2322,11 +2324,11 @@ isdn_net_find_icall(int di, int ch, int idx, setup_parm *setup)
2322 * */ 2324 * */
2323 if (ISDN_NET_DIALMODE(*lp) == ISDN_NET_DM_OFF) { 2325 if (ISDN_NET_DIALMODE(*lp) == ISDN_NET_DM_OFF) {
2324 printk(KERN_INFO "incoming call for callback, interface %s `off' -> rejected\n", 2326 printk(KERN_INFO "incoming call for callback, interface %s `off' -> rejected\n",
2325 lp->name); 2327 p->dev->name);
2326 return 3; 2328 return 3;
2327 } 2329 }
2328 printk(KERN_DEBUG "%s: call from %s -> %s, start callback\n", 2330 printk(KERN_DEBUG "%s: call from %s -> %s, start callback\n",
2329 lp->name, nr, eaz); 2331 p->dev->name, nr, eaz);
2330 if (lp->phone[1]) { 2332 if (lp->phone[1]) {
2331 /* Grab a free ISDN-Channel */ 2333 /* Grab a free ISDN-Channel */
2332 spin_lock_irqsave(&dev->lock, flags); 2334 spin_lock_irqsave(&dev->lock, flags);
@@ -2340,7 +2342,8 @@ isdn_net_find_icall(int di, int ch, int idx, setup_parm *setup)
2340 lp->msn) 2342 lp->msn)
2341 ) < 0) { 2343 ) < 0) {
2342 2344
2343 printk(KERN_WARNING "isdn_net_find_icall: No channel for %s\n", lp->name); 2345 printk(KERN_WARNING "isdn_net_find_icall: No channel for %s\n",
2346 p->dev->name);
2344 spin_unlock_irqrestore(&dev->lock, flags); 2347 spin_unlock_irqrestore(&dev->lock, flags);
2345 return 0; 2348 return 0;
2346 } 2349 }
@@ -2361,11 +2364,12 @@ isdn_net_find_icall(int di, int ch, int idx, setup_parm *setup)
2361 /* Initiate dialing by returning 2 or 4 */ 2364 /* Initiate dialing by returning 2 or 4 */
2362 return (lp->flags & ISDN_NET_CBHUP) ? 2 : 4; 2365 return (lp->flags & ISDN_NET_CBHUP) ? 2 : 4;
2363 } else 2366 } else
2364 printk(KERN_WARNING "isdn_net: %s: No phone number\n", lp->name); 2367 printk(KERN_WARNING "isdn_net: %s: No phone number\n",
2368 p->dev->name);
2365 return 0; 2369 return 0;
2366 } else { 2370 } else {
2367 printk(KERN_DEBUG "%s: call from %s -> %s accepted\n", lp->name, nr, 2371 printk(KERN_DEBUG "%s: call from %s -> %s accepted\n",
2368 eaz); 2372 p->dev->name, nr, eaz);
2369 /* if this interface is dialing, it does it probably on a different 2373 /* if this interface is dialing, it does it probably on a different
2370 device, so free this device */ 2374 device, so free this device */
2371 if ((lp->dialstate == 4) || (lp->dialstate == 12)) { 2375 if ((lp->dialstate == 4) || (lp->dialstate == 12)) {
@@ -2424,7 +2428,7 @@ isdn_net_findif(char *name)
2424 isdn_net_dev *p = dev->netdev; 2428 isdn_net_dev *p = dev->netdev;
2425 2429
2426 while (p) { 2430 while (p) {
2427 if (!strcmp(p->local->name, name)) 2431 if (!strcmp(p->dev->name, name))
2428 return p; 2432 return p;
2429 p = (isdn_net_dev *) p->next; 2433 p = (isdn_net_dev *) p->next;
2430 } 2434 }
@@ -2453,7 +2457,8 @@ isdn_net_force_dial_lp(isdn_net_local * lp)
2453 lp->pre_device, 2457 lp->pre_device,
2454 lp->pre_channel, 2458 lp->pre_channel,
2455 lp->msn)) < 0) { 2459 lp->msn)) < 0) {
2456 printk(KERN_WARNING "isdn_net_force_dial: No channel for %s\n", lp->name); 2460 printk(KERN_WARNING "isdn_net_force_dial: No channel for %s\n",
2461 lp->netdev->dev->name);
2457 spin_unlock_irqrestore(&dev->lock, flags); 2462 spin_unlock_irqrestore(&dev->lock, flags);
2458 return -EAGAIN; 2463 return -EAGAIN;
2459 } 2464 }
@@ -2556,7 +2561,7 @@ isdn_net_new(char *name, struct net_device *master)
2556 return NULL; 2561 return NULL;
2557 } 2562 }
2558 if (name == NULL) 2563 if (name == NULL)
2559 name = " "; 2564 return NULL;
2560 if (!(netdev = kzalloc(sizeof(isdn_net_dev), GFP_KERNEL))) { 2565 if (!(netdev = kzalloc(sizeof(isdn_net_dev), GFP_KERNEL))) {
2561 printk(KERN_WARNING "isdn_net: Could not allocate net-device\n"); 2566 printk(KERN_WARNING "isdn_net: Could not allocate net-device\n");
2562 return NULL; 2567 return NULL;
@@ -2568,7 +2573,6 @@ isdn_net_new(char *name, struct net_device *master)
2568 return NULL; 2573 return NULL;
2569 } 2574 }
2570 netdev->local = netdev->dev->priv; 2575 netdev->local = netdev->dev->priv;
2571 strcpy(netdev->local->name, netdev->dev->name);
2572 netdev->dev->init = isdn_net_init; 2576 netdev->dev->init = isdn_net_init;
2573 if (master) { 2577 if (master) {
2574 /* Device shall be a slave */ 2578 /* Device shall be a slave */
@@ -2673,7 +2677,7 @@ isdn_net_setcfg(isdn_net_ioctl_cfg * cfg)
2673#endif 2677#endif
2674 if (isdn_net_device_started(p)) { 2678 if (isdn_net_device_started(p)) {
2675 printk(KERN_WARNING "%s: cannot change encap when if is up\n", 2679 printk(KERN_WARNING "%s: cannot change encap when if is up\n",
2676 lp->name); 2680 p->dev->name);
2677 return -EBUSY; 2681 return -EBUSY;
2678 } 2682 }
2679#ifdef CONFIG_ISDN_X25 2683#ifdef CONFIG_ISDN_X25
@@ -2698,7 +2702,7 @@ isdn_net_setcfg(isdn_net_ioctl_cfg * cfg)
2698 case ISDN_NET_ENCAP_SYNCPPP: 2702 case ISDN_NET_ENCAP_SYNCPPP:
2699#ifndef CONFIG_ISDN_PPP 2703#ifndef CONFIG_ISDN_PPP
2700 printk(KERN_WARNING "%s: SyncPPP support not configured\n", 2704 printk(KERN_WARNING "%s: SyncPPP support not configured\n",
2701 lp->name); 2705 p->dev->name);
2702 return -EINVAL; 2706 return -EINVAL;
2703#else 2707#else
2704 p->dev->type = ARPHRD_PPP; /* change ARP type */ 2708 p->dev->type = ARPHRD_PPP; /* change ARP type */
@@ -2725,7 +2729,7 @@ isdn_net_setcfg(isdn_net_ioctl_cfg * cfg)
2725 break; 2729 break;
2726 printk(KERN_WARNING 2730 printk(KERN_WARNING
2727 "%s: encapsulation protocol %d not supported\n", 2731 "%s: encapsulation protocol %d not supported\n",
2728 p->local->name, cfg->p_encap); 2732 p->dev->name, cfg->p_encap);
2729 return -EINVAL; 2733 return -EINVAL;
2730 } 2734 }
2731 if (strlen(cfg->drvid)) { 2735 if (strlen(cfg->drvid)) {
@@ -2902,13 +2906,18 @@ isdn_net_getcfg(isdn_net_ioctl_cfg * cfg)
2902 cfg->pppbind = lp->pppbind; 2906 cfg->pppbind = lp->pppbind;
2903 cfg->dialtimeout = lp->dialtimeout >= 0 ? lp->dialtimeout / HZ : -1; 2907 cfg->dialtimeout = lp->dialtimeout >= 0 ? lp->dialtimeout / HZ : -1;
2904 cfg->dialwait = lp->dialwait / HZ; 2908 cfg->dialwait = lp->dialwait / HZ;
2905 if (lp->slave) 2909 if (lp->slave) {
2906 strcpy(cfg->slave, ((isdn_net_local *) lp->slave->priv)->name); 2910 if (strlen(lp->slave->name) > 8)
2907 else 2911 strcpy(cfg->slave, "too-long");
2912 else
2913 strcpy(cfg->slave, lp->slave->name);
2914 } else
2908 cfg->slave[0] = '\0'; 2915 cfg->slave[0] = '\0';
2909 if (lp->master) 2916 if (lp->master) {
2910 strcpy(cfg->master, ((isdn_net_local *) lp->master->priv)->name); 2917 if (strlen(lp->master->name) > 8)
2911 else 2918 strcpy(cfg->master, "too-long");
2919 strcpy(cfg->master, lp->master->name);
2920 } else
2912 cfg->master[0] = '\0'; 2921 cfg->master[0] = '\0';
2913 return 0; 2922 return 0;
2914 } 2923 }
@@ -2978,7 +2987,8 @@ isdn_net_getpeer(isdn_net_ioctl_phone *phone, isdn_net_ioctl_phone __user *peer)
2978 isdn_net_dev *p = isdn_net_findif(phone->name); 2987 isdn_net_dev *p = isdn_net_findif(phone->name);
2979 int ch, dv, idx; 2988 int ch, dv, idx;
2980 2989
2981 if (!p) return -ENODEV; 2990 if (!p)
2991 return -ENODEV;
2982 /* 2992 /*
2983 * Theoretical race: while this executes, the remote number might 2993 * Theoretical race: while this executes, the remote number might
2984 * become invalid (hang up) or change (new connection), resulting 2994 * become invalid (hang up) or change (new connection), resulting
@@ -2987,14 +2997,18 @@ isdn_net_getpeer(isdn_net_ioctl_phone *phone, isdn_net_ioctl_phone __user *peer)
2987 */ 2997 */
2988 ch = p->local->isdn_channel; 2998 ch = p->local->isdn_channel;
2989 dv = p->local->isdn_device; 2999 dv = p->local->isdn_device;
2990 if(ch<0 && dv<0) return -ENOTCONN; 3000 if(ch < 0 && dv < 0)
3001 return -ENOTCONN;
2991 idx = isdn_dc2minor(dv, ch); 3002 idx = isdn_dc2minor(dv, ch);
2992 if (idx<0) return -ENODEV; 3003 if (idx <0 )
3004 return -ENODEV;
2993 /* for pre-bound channels, we need this extra check */ 3005 /* for pre-bound channels, we need this extra check */
2994 if ( strncmp(dev->num[idx],"???",3) == 0 ) return -ENOTCONN; 3006 if (strncmp(dev->num[idx], "???", 3) == 0)
2995 strncpy(phone->phone,dev->num[idx],ISDN_MSNLEN); 3007 return -ENOTCONN;
2996 phone->outgoing=USG_OUTGOING(dev->usage[idx]); 3008 strncpy(phone->phone, dev->num[idx], ISDN_MSNLEN);
2997 if ( copy_to_user(peer,phone,sizeof(*peer)) ) return -EFAULT; 3009 phone->outgoing = USG_OUTGOING(dev->usage[idx]);
3010 if (copy_to_user(peer, phone, sizeof(*peer)))
3011 return -EFAULT;
2998 return 0; 3012 return 0;
2999} 3013}
3000/* 3014/*
@@ -3113,18 +3127,18 @@ isdn_net_realrm(isdn_net_dev * p, isdn_net_dev * q)
3113 dev->netdev = p->next; 3127 dev->netdev = p->next;
3114 if (p->local->slave) { 3128 if (p->local->slave) {
3115 /* If this interface has a slave, remove it also */ 3129 /* If this interface has a slave, remove it also */
3116 char *slavename = ((isdn_net_local *) (p->local->slave->priv))->name; 3130 char *slavename = p->local->slave->name;
3117 isdn_net_dev *n = dev->netdev; 3131 isdn_net_dev *n = dev->netdev;
3118 q = NULL; 3132 q = NULL;
3119 while (n) { 3133 while (n) {
3120 if (!strcmp(n->local->name, slavename)) { 3134 if (!strcmp(n->dev->name, slavename)) {
3121 spin_unlock_irqrestore(&dev->lock, flags); 3135 spin_unlock_irqrestore(&dev->lock, flags);
3122 isdn_net_realrm(n, q); 3136 isdn_net_realrm(n, q);
3123 spin_lock_irqsave(&dev->lock, flags); 3137 spin_lock_irqsave(&dev->lock, flags);
3124 break; 3138 break;
3125 } 3139 }
3126 q = n; 3140 q = n;
3127 n = (isdn_net_dev *) n->next; 3141 n = (isdn_net_dev *)n->next;
3128 } 3142 }
3129 } 3143 }
3130 spin_unlock_irqrestore(&dev->lock, flags); 3144 spin_unlock_irqrestore(&dev->lock, flags);
@@ -3152,7 +3166,7 @@ isdn_net_rm(char *name)
3152 p = dev->netdev; 3166 p = dev->netdev;
3153 q = NULL; 3167 q = NULL;
3154 while (p) { 3168 while (p) {
3155 if (!strcmp(p->local->name, name)) { 3169 if (!strcmp(p->dev->name, name)) {
3156 spin_unlock_irqrestore(&dev->lock, flags); 3170 spin_unlock_irqrestore(&dev->lock, flags);
3157 return (isdn_net_realrm(p, q)); 3171 return (isdn_net_realrm(p, q));
3158 } 3172 }