aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/slip.c367
1 files changed, 178 insertions, 189 deletions
diff --git a/drivers/net/slip.c b/drivers/net/slip.c
index 251a3ce376ac..5a55ede352f4 100644
--- a/drivers/net/slip.c
+++ b/drivers/net/slip.c
@@ -11,9 +11,11 @@
11 * Fixes: 11 * Fixes:
12 * Alan Cox : Sanity checks and avoid tx overruns. 12 * Alan Cox : Sanity checks and avoid tx overruns.
13 * Has a new sl->mtu field. 13 * Has a new sl->mtu field.
14 * Alan Cox : Found cause of overrun. ifconfig sl0 mtu upwards. 14 * Alan Cox : Found cause of overrun. ifconfig sl0
15 * Driver now spots this and grows/shrinks its buffers(hack!). 15 * mtu upwards. Driver now spots this
16 * Memory leak if you run out of memory setting up a slip driver fixed. 16 * and grows/shrinks its buffers(hack!).
17 * Memory leak if you run out of memory
18 * setting up a slip driver fixed.
17 * Matt Dillon : Printable slip (borrowed from NET2E) 19 * Matt Dillon : Printable slip (borrowed from NET2E)
18 * Pauline Middelink : Slip driver fixes. 20 * Pauline Middelink : Slip driver fixes.
19 * Alan Cox : Honours the old SL_COMPRESSED flag 21 * Alan Cox : Honours the old SL_COMPRESSED flag
@@ -29,7 +31,8 @@
29 * buffering from 4096 to 256 bytes. 31 * buffering from 4096 to 256 bytes.
30 * Improving SLIP response time. 32 * Improving SLIP response time.
31 * CONFIG_SLIP_MODE_SLIP6. 33 * CONFIG_SLIP_MODE_SLIP6.
32 * ifconfig sl? up & down now works correctly. 34 * ifconfig sl? up & down now works
35 * correctly.
33 * Modularization. 36 * Modularization.
34 * Alan Cox : Oops - fix AX.25 buffer lengths 37 * Alan Cox : Oops - fix AX.25 buffer lengths
35 * Dmitry Gorodchanin : Even more cleanups. Preserve CSLIP 38 * Dmitry Gorodchanin : Even more cleanups. Preserve CSLIP
@@ -43,15 +46,18 @@
43 * device entries, just reg./unreg. them 46 * device entries, just reg./unreg. them
44 * as they are needed. We kfree() them 47 * as they are needed. We kfree() them
45 * at module cleanup. 48 * at module cleanup.
46 * With MODULE-loading ``insmod'', user can 49 * With MODULE-loading ``insmod'', user
47 * issue parameter: slip_maxdev=1024 50 * can issue parameter: slip_maxdev=1024
48 * (Or how much he/she wants.. Default is 256) 51 * (Or how much he/she wants.. Default
49 * * Stanislav Voronyi : Slip line checking, with ideas taken 52 * is 256)
50 * from multislip BSDI driver which was written 53 * Stanislav Voronyi : Slip line checking, with ideas taken
51 * by Igor Chechik, RELCOM Corp. Only algorithms 54 * from multislip BSDI driver which was
52 * have been ported to Linux SLIP driver. 55 * written by Igor Chechik, RELCOM Corp.
56 * Only algorithms have been ported to
57 * Linux SLIP driver.
53 * Vitaly E. Lavrov : Sane behaviour on tty hangup. 58 * Vitaly E. Lavrov : Sane behaviour on tty hangup.
54 * Alexey Kuznetsov : Cleanup interfaces to tty&netdevice modules. 59 * Alexey Kuznetsov : Cleanup interfaces to tty & netdevice
60 * modules.
55 */ 61 */
56 62
57#define SL_CHECK_TRANSMIT 63#define SL_CHECK_TRANSMIT
@@ -99,7 +105,7 @@ static void slip_unesc6(struct slip *sl, unsigned char c);
99#ifdef CONFIG_SLIP_SMART 105#ifdef CONFIG_SLIP_SMART
100static void sl_keepalive(unsigned long sls); 106static void sl_keepalive(unsigned long sls);
101static void sl_outfill(unsigned long sls); 107static void sl_outfill(unsigned long sls);
102static int sl_ioctl(struct net_device *dev,struct ifreq *rq,int cmd); 108static int sl_ioctl(struct net_device *dev, struct ifreq *rq, int cmd);
103#endif 109#endif
104 110
105/******************************** 111/********************************
@@ -117,15 +123,14 @@ static int sl_ioctl(struct net_device *dev,struct ifreq *rq,int cmd);
117 Allocate channel buffers. 123 Allocate channel buffers.
118 */ 124 */
119 125
120static int 126static int sl_alloc_bufs(struct slip *sl, int mtu)
121sl_alloc_bufs(struct slip *sl, int mtu)
122{ 127{
123 int err = -ENOBUFS; 128 int err = -ENOBUFS;
124 unsigned long len; 129 unsigned long len;
125 char * rbuff = NULL; 130 char *rbuff = NULL;
126 char * xbuff = NULL; 131 char *xbuff = NULL;
127#ifdef SL_INCLUDE_CSLIP 132#ifdef SL_INCLUDE_CSLIP
128 char * cbuff = NULL; 133 char *cbuff = NULL;
129 struct slcompress *slcomp = NULL; 134 struct slcompress *slcomp = NULL;
130#endif 135#endif
131 136
@@ -195,8 +200,7 @@ err_exit:
195} 200}
196 201
197/* Free a SLIP channel buffers. */ 202/* Free a SLIP channel buffers. */
198static void 203static void sl_free_bufs(struct slip *sl)
199sl_free_bufs(struct slip *sl)
200{ 204{
201 /* Free all SLIP frame buffers. */ 205 /* Free all SLIP frame buffers. */
202 kfree(xchg(&sl->rbuff, NULL)); 206 kfree(xchg(&sl->rbuff, NULL));
@@ -248,7 +252,6 @@ static int sl_realloc_bufs(struct slip *sl, int mtu)
248 } 252 }
249 goto done; 253 goto done;
250 } 254 }
251
252 spin_lock_bh(&sl->lock); 255 spin_lock_bh(&sl->lock);
253 256
254 err = -ENODEV; 257 err = -ENODEV;
@@ -298,23 +301,20 @@ done:
298 301
299 302
300/* Set the "sending" flag. This must be atomic hence the set_bit. */ 303/* Set the "sending" flag. This must be atomic hence the set_bit. */
301static inline void 304static inline void sl_lock(struct slip *sl)
302sl_lock(struct slip *sl)
303{ 305{
304 netif_stop_queue(sl->dev); 306 netif_stop_queue(sl->dev);
305} 307}
306 308
307 309
308/* Clear the "sending" flag. This must be atomic, hence the ASM. */ 310/* Clear the "sending" flag. This must be atomic, hence the ASM. */
309static inline void 311static inline void sl_unlock(struct slip *sl)
310sl_unlock(struct slip *sl)
311{ 312{
312 netif_wake_queue(sl->dev); 313 netif_wake_queue(sl->dev);
313} 314}
314 315
315/* Send one completely decapsulated IP datagram to the IP layer. */ 316/* Send one completely decapsulated IP datagram to the IP layer. */
316static void 317static void sl_bump(struct slip *sl)
317sl_bump(struct slip *sl)
318{ 318{
319 struct sk_buff *skb; 319 struct sk_buff *skb;
320 int count; 320 int count;
@@ -322,22 +322,22 @@ sl_bump(struct slip *sl)
322 count = sl->rcount; 322 count = sl->rcount;
323#ifdef SL_INCLUDE_CSLIP 323#ifdef SL_INCLUDE_CSLIP
324 if (sl->mode & (SL_MODE_ADAPTIVE | SL_MODE_CSLIP)) { 324 if (sl->mode & (SL_MODE_ADAPTIVE | SL_MODE_CSLIP)) {
325 unsigned char c; 325 unsigned char c = sl->rbuff[0];
326 if ((c = sl->rbuff[0]) & SL_TYPE_COMPRESSED_TCP) { 326 if (c & SL_TYPE_COMPRESSED_TCP) {
327 /* ignore compressed packets when CSLIP is off */ 327 /* ignore compressed packets when CSLIP is off */
328 if (!(sl->mode & SL_MODE_CSLIP)) { 328 if (!(sl->mode & SL_MODE_CSLIP)) {
329 printk(KERN_WARNING "%s: compressed packet ignored\n", sl->dev->name); 329 printk(KERN_WARNING "%s: compressed packet ignored\n", sl->dev->name);
330 return; 330 return;
331 } 331 }
332 /* make sure we've reserved enough space for uncompress to use */ 332 /* make sure we've reserved enough space for uncompress
333 to use */
333 if (count + 80 > sl->buffsize) { 334 if (count + 80 > sl->buffsize) {
334 sl->rx_over_errors++; 335 sl->rx_over_errors++;
335 return; 336 return;
336 } 337 }
337 count = slhc_uncompress(sl->slcomp, sl->rbuff, count); 338 count = slhc_uncompress(sl->slcomp, sl->rbuff, count);
338 if (count <= 0) { 339 if (count <= 0)
339 return; 340 return;
340 }
341 } else if (c >= SL_TYPE_UNCOMPRESSED_TCP) { 341 } else if (c >= SL_TYPE_UNCOMPRESSED_TCP) {
342 if (!(sl->mode & SL_MODE_CSLIP)) { 342 if (!(sl->mode & SL_MODE_CSLIP)) {
343 /* turn on header compression */ 343 /* turn on header compression */
@@ -346,33 +346,31 @@ sl_bump(struct slip *sl)
346 printk(KERN_INFO "%s: header compression turned on\n", sl->dev->name); 346 printk(KERN_INFO "%s: header compression turned on\n", sl->dev->name);
347 } 347 }
348 sl->rbuff[0] &= 0x4f; 348 sl->rbuff[0] &= 0x4f;
349 if (slhc_remember(sl->slcomp, sl->rbuff, count) <= 0) { 349 if (slhc_remember(sl->slcomp, sl->rbuff, count) <= 0)
350 return; 350 return;
351 }
352 } 351 }
353 } 352 }
354#endif /* SL_INCLUDE_CSLIP */ 353#endif /* SL_INCLUDE_CSLIP */
355 354
356 sl->rx_bytes+=count; 355 sl->rx_bytes += count;
357 356
358 skb = dev_alloc_skb(count); 357 skb = dev_alloc_skb(count);
359 if (skb == NULL) { 358 if (skb == NULL) {
360 printk(KERN_WARNING "%s: memory squeeze, dropping packet.\n", sl->dev->name); 359 printk(KERN_WARNING "%s: memory squeeze, dropping packet.\n", sl->dev->name);
361 sl->rx_dropped++; 360 sl->rx_dropped++;
362 return; 361 return;
363 } 362 }
364 skb->dev = sl->dev; 363 skb->dev = sl->dev;
365 memcpy(skb_put(skb,count), sl->rbuff, count); 364 memcpy(skb_put(skb, count), sl->rbuff, count);
366 skb_reset_mac_header(skb); 365 skb_reset_mac_header(skb);
367 skb->protocol=htons(ETH_P_IP); 366 skb->protocol = htons(ETH_P_IP);
368 netif_rx(skb); 367 netif_rx(skb);
369 sl->dev->last_rx = jiffies; 368 sl->dev->last_rx = jiffies;
370 sl->rx_packets++; 369 sl->rx_packets++;
371} 370}
372 371
373/* Encapsulate one IP datagram and stuff into a TTY queue. */ 372/* Encapsulate one IP datagram and stuff into a TTY queue. */
374static void 373static void sl_encaps(struct slip *sl, unsigned char *icp, int len)
375sl_encaps(struct slip *sl, unsigned char *icp, int len)
376{ 374{
377 unsigned char *p; 375 unsigned char *p;
378 int actual, count; 376 int actual, count;
@@ -386,12 +384,11 @@ sl_encaps(struct slip *sl, unsigned char *icp, int len)
386 384
387 p = icp; 385 p = icp;
388#ifdef SL_INCLUDE_CSLIP 386#ifdef SL_INCLUDE_CSLIP
389 if (sl->mode & SL_MODE_CSLIP) { 387 if (sl->mode & SL_MODE_CSLIP)
390 len = slhc_compress(sl->slcomp, p, len, sl->cbuff, &p, 1); 388 len = slhc_compress(sl->slcomp, p, len, sl->cbuff, &p, 1);
391 }
392#endif 389#endif
393#ifdef CONFIG_SLIP_MODE_SLIP6 390#ifdef CONFIG_SLIP_MODE_SLIP6
394 if(sl->mode & SL_MODE_SLIP6) 391 if (sl->mode & SL_MODE_SLIP6)
395 count = slip_esc6(p, (unsigned char *) sl->xbuff, len); 392 count = slip_esc6(p, (unsigned char *) sl->xbuff, len);
396 else 393 else
397#endif 394#endif
@@ -425,12 +422,12 @@ sl_encaps(struct slip *sl, unsigned char *icp, int len)
425static void slip_write_wakeup(struct tty_struct *tty) 422static void slip_write_wakeup(struct tty_struct *tty)
426{ 423{
427 int actual; 424 int actual;
428 struct slip *sl = (struct slip *) tty->disc_data; 425 struct slip *sl = tty->disc_data;
429 426
430 /* First make sure we're connected. */ 427 /* First make sure we're connected. */
431 if (!sl || sl->magic != SLIP_MAGIC || !netif_running(sl->dev)) { 428 if (!sl || sl->magic != SLIP_MAGIC || !netif_running(sl->dev))
432 return; 429 return;
433 } 430
434 if (sl->xleft <= 0) { 431 if (sl->xleft <= 0) {
435 /* Now serial buffer is almost free & we can start 432 /* Now serial buffer is almost free & we can start
436 * transmission of another packet */ 433 * transmission of another packet */
@@ -463,15 +460,15 @@ static void sl_tx_timeout(struct net_device *dev)
463 /* 20 sec timeout not reached */ 460 /* 20 sec timeout not reached */
464 goto out; 461 goto out;
465 } 462 }
466 printk(KERN_WARNING "%s: transmit timed out, %s?\n", dev->name, 463 printk(KERN_WARNING "%s: transmit timed out, %s?\n",
467 (sl->tty->driver->chars_in_buffer(sl->tty) || sl->xleft) ? 464 dev->name,
468 "bad line quality" : "driver error"); 465 (sl->tty->driver->chars_in_buffer(sl->tty) || sl->xleft) ?
466 "bad line quality" : "driver error");
469 sl->xleft = 0; 467 sl->xleft = 0;
470 sl->tty->flags &= ~(1 << TTY_DO_WRITE_WAKEUP); 468 sl->tty->flags &= ~(1 << TTY_DO_WRITE_WAKEUP);
471 sl_unlock(sl); 469 sl_unlock(sl);
472#endif 470#endif
473 } 471 }
474
475out: 472out:
476 spin_unlock(&sl->lock); 473 spin_unlock(&sl->lock);
477} 474}
@@ -484,7 +481,7 @@ sl_xmit(struct sk_buff *skb, struct net_device *dev)
484 struct slip *sl = netdev_priv(dev); 481 struct slip *sl = netdev_priv(dev);
485 482
486 spin_lock(&sl->lock); 483 spin_lock(&sl->lock);
487 if (!netif_running(dev)) { 484 if (!netif_running(dev)) {
488 spin_unlock(&sl->lock); 485 spin_unlock(&sl->lock);
489 printk(KERN_WARNING "%s: xmit call when iface is down\n", dev->name); 486 printk(KERN_WARNING "%s: xmit call when iface is down\n", dev->name);
490 dev_kfree_skb(skb); 487 dev_kfree_skb(skb);
@@ -497,7 +494,7 @@ sl_xmit(struct sk_buff *skb, struct net_device *dev)
497 } 494 }
498 495
499 sl_lock(sl); 496 sl_lock(sl);
500 sl->tx_bytes+=skb->len; 497 sl->tx_bytes += skb->len;
501 sl_encaps(sl, skb->data, skb->len); 498 sl_encaps(sl, skb->data, skb->len);
502 spin_unlock(&sl->lock); 499 spin_unlock(&sl->lock);
503 500
@@ -536,7 +533,7 @@ static int sl_open(struct net_device *dev)
536{ 533{
537 struct slip *sl = netdev_priv(dev); 534 struct slip *sl = netdev_priv(dev);
538 535
539 if (sl->tty==NULL) 536 if (sl->tty == NULL)
540 return -ENODEV; 537 return -ENODEV;
541 538
542 sl->flags &= (1 << SLF_INUSE); 539 sl->flags &= (1 << SLF_INUSE);
@@ -657,20 +654,19 @@ static void sl_setup(struct net_device *dev)
657 * in parallel 654 * in parallel
658 */ 655 */
659 656
660static void slip_receive_buf(struct tty_struct *tty, const unsigned char *cp, char *fp, int count) 657static void slip_receive_buf(struct tty_struct *tty, const unsigned char *cp,
658 char *fp, int count)
661{ 659{
662 struct slip *sl = (struct slip *) tty->disc_data; 660 struct slip *sl = tty->disc_data;
663 661
664 if (!sl || sl->magic != SLIP_MAGIC || 662 if (!sl || sl->magic != SLIP_MAGIC || !netif_running(sl->dev))
665 !netif_running(sl->dev))
666 return; 663 return;
667 664
668 /* Read the characters out of the buffer */ 665 /* Read the characters out of the buffer */
669 while (count--) { 666 while (count--) {
670 if (fp && *fp++) { 667 if (fp && *fp++) {
671 if (!test_and_set_bit(SLF_ERROR, &sl->flags)) { 668 if (!test_and_set_bit(SLF_ERROR, &sl->flags))
672 sl->rx_errors++; 669 sl->rx_errors++;
673 }
674 cp++; 670 cp++;
675 continue; 671 continue;
676 } 672 }
@@ -688,7 +684,6 @@ static void slip_receive_buf(struct tty_struct *tty, const unsigned char *cp, ch
688 ************************************/ 684 ************************************/
689 685
690/* Collect hanged up channels */ 686/* Collect hanged up channels */
691
692static void sl_sync(void) 687static void sl_sync(void)
693{ 688{
694 int i; 689 int i;
@@ -696,21 +691,21 @@ static void sl_sync(void)
696 struct slip *sl; 691 struct slip *sl;
697 692
698 for (i = 0; i < slip_maxdev; i++) { 693 for (i = 0; i < slip_maxdev; i++) {
699 if ((dev = slip_devs[i]) == NULL) 694 dev = slip_devs[i];
695 if (dev == NULL)
700 break; 696 break;
701 697
702 sl = netdev_priv(dev); 698 sl = netdev_priv(dev);
703 if (sl->tty || sl->leased) 699 if (sl->tty || sl->leased)
704 continue; 700 continue;
705 if (dev->flags&IFF_UP) 701 if (dev->flags & IFF_UP)
706 dev_close(dev); 702 dev_close(dev);
707 } 703 }
708} 704}
709 705
710 706
711/* Find a free SLIP channel, and link in this `tty' line. */ 707/* Find a free SLIP channel, and link in this `tty' line. */
712static struct slip * 708static struct slip *sl_alloc(dev_t line)
713sl_alloc(dev_t line)
714{ 709{
715 int i; 710 int i;
716 int sel = -1; 711 int sel = -1;
@@ -805,15 +800,15 @@ sl_alloc(dev_t line)
805 spin_lock_init(&sl->lock); 800 spin_lock_init(&sl->lock);
806 sl->mode = SL_MODE_DEFAULT; 801 sl->mode = SL_MODE_DEFAULT;
807#ifdef CONFIG_SLIP_SMART 802#ifdef CONFIG_SLIP_SMART
808 init_timer(&sl->keepalive_timer); /* initialize timer_list struct */ 803 /* initialize timer_list struct */
809 sl->keepalive_timer.data=(unsigned long)sl; 804 init_timer(&sl->keepalive_timer);
810 sl->keepalive_timer.function=sl_keepalive; 805 sl->keepalive_timer.data = (unsigned long)sl;
806 sl->keepalive_timer.function = sl_keepalive;
811 init_timer(&sl->outfill_timer); 807 init_timer(&sl->outfill_timer);
812 sl->outfill_timer.data=(unsigned long)sl; 808 sl->outfill_timer.data = (unsigned long)sl;
813 sl->outfill_timer.function=sl_outfill; 809 sl->outfill_timer.function = sl_outfill;
814#endif 810#endif
815 slip_devs[i] = dev; 811 slip_devs[i] = dev;
816
817 return sl; 812 return sl;
818} 813}
819 814
@@ -832,7 +827,7 @@ static int slip_open(struct tty_struct *tty)
832 struct slip *sl; 827 struct slip *sl;
833 int err; 828 int err;
834 829
835 if(!capable(CAP_NET_ADMIN)) 830 if (!capable(CAP_NET_ADMIN))
836 return -EPERM; 831 return -EPERM;
837 832
838 /* RTnetlink lock is misused here to serialize concurrent 833 /* RTnetlink lock is misused here to serialize concurrent
@@ -844,7 +839,7 @@ static int slip_open(struct tty_struct *tty)
844 /* Collect hanged up channels. */ 839 /* Collect hanged up channels. */
845 sl_sync(); 840 sl_sync();
846 841
847 sl = (struct slip *) tty->disc_data; 842 sl = tty->disc_data;
848 843
849 err = -EEXIST; 844 err = -EEXIST;
850 /* First make sure we're not already connected. */ 845 /* First make sure we're not already connected. */
@@ -853,7 +848,8 @@ static int slip_open(struct tty_struct *tty)
853 848
854 /* OK. Find a free SLIP channel to use. */ 849 /* OK. Find a free SLIP channel to use. */
855 err = -ENFILE; 850 err = -ENFILE;
856 if ((sl = sl_alloc(tty_devnum(tty))) == NULL) 851 sl = sl_alloc(tty_devnum(tty));
852 if (sl == NULL)
857 goto err_exit; 853 goto err_exit;
858 854
859 sl->tty = tty; 855 sl->tty = tty;
@@ -863,23 +859,25 @@ static int slip_open(struct tty_struct *tty)
863 859
864 if (!test_bit(SLF_INUSE, &sl->flags)) { 860 if (!test_bit(SLF_INUSE, &sl->flags)) {
865 /* Perform the low-level SLIP initialization. */ 861 /* Perform the low-level SLIP initialization. */
866 if ((err = sl_alloc_bufs(sl, SL_MTU)) != 0) 862 err = sl_alloc_bufs(sl, SL_MTU);
863 if (err)
867 goto err_free_chan; 864 goto err_free_chan;
868 865
869 set_bit(SLF_INUSE, &sl->flags); 866 set_bit(SLF_INUSE, &sl->flags);
870 867
871 if ((err = register_netdevice(sl->dev))) 868 err = register_netdevice(sl->dev);
869 if (err)
872 goto err_free_bufs; 870 goto err_free_bufs;
873 } 871 }
874 872
875#ifdef CONFIG_SLIP_SMART 873#ifdef CONFIG_SLIP_SMART
876 if (sl->keepalive) { 874 if (sl->keepalive) {
877 sl->keepalive_timer.expires=jiffies+sl->keepalive*HZ; 875 sl->keepalive_timer.expires = jiffies + sl->keepalive * HZ;
878 add_timer (&sl->keepalive_timer); 876 add_timer(&sl->keepalive_timer);
879 } 877 }
880 if (sl->outfill) { 878 if (sl->outfill) {
881 sl->outfill_timer.expires=jiffies+sl->outfill*HZ; 879 sl->outfill_timer.expires = jiffies + sl->outfill * HZ;
882 add_timer (&sl->outfill_timer); 880 add_timer(&sl->outfill_timer);
883 } 881 }
884#endif 882#endif
885 883
@@ -928,10 +926,9 @@ err_exit:
928 * This means flushing out any pending queues, and then returning. This 926 * This means flushing out any pending queues, and then returning. This
929 * call is serialized against other ldisc functions. 927 * call is serialized against other ldisc functions.
930 */ 928 */
931static void 929static void slip_close(struct tty_struct *tty)
932slip_close(struct tty_struct *tty)
933{ 930{
934 struct slip *sl = (struct slip *) tty->disc_data; 931 struct slip *sl = tty->disc_data;
935 932
936 /* First make sure we're connected. */ 933 /* First make sure we're connected. */
937 if (!sl || sl->magic != SLIP_MAGIC || sl->tty != tty) 934 if (!sl || sl->magic != SLIP_MAGIC || sl->tty != tty)
@@ -955,8 +952,7 @@ slip_close(struct tty_struct *tty)
955 * STANDARD SLIP ENCAPSULATION * 952 * STANDARD SLIP ENCAPSULATION *
956 ************************************************************************/ 953 ************************************************************************/
957 954
958static int 955static int slip_esc(unsigned char *s, unsigned char *d, int len)
959slip_esc(unsigned char *s, unsigned char *d, int len)
960{ 956{
961 unsigned char *ptr = d; 957 unsigned char *ptr = d;
962 unsigned char c; 958 unsigned char c;
@@ -975,16 +971,16 @@ slip_esc(unsigned char *s, unsigned char *d, int len)
975 */ 971 */
976 972
977 while (len-- > 0) { 973 while (len-- > 0) {
978 switch(c = *s++) { 974 switch (c = *s++) {
979 case END: 975 case END:
980 *ptr++ = ESC; 976 *ptr++ = ESC;
981 *ptr++ = ESC_END; 977 *ptr++ = ESC_END;
982 break; 978 break;
983 case ESC: 979 case ESC:
984 *ptr++ = ESC; 980 *ptr++ = ESC;
985 *ptr++ = ESC_ESC; 981 *ptr++ = ESC_ESC;
986 break; 982 break;
987 default: 983 default:
988 *ptr++ = c; 984 *ptr++ = c;
989 break; 985 break;
990 } 986 }
@@ -996,33 +992,31 @@ slip_esc(unsigned char *s, unsigned char *d, int len)
996static void slip_unesc(struct slip *sl, unsigned char s) 992static void slip_unesc(struct slip *sl, unsigned char s)
997{ 993{
998 994
999 switch(s) { 995 switch (s) {
1000 case END: 996 case END:
1001#ifdef CONFIG_SLIP_SMART 997#ifdef CONFIG_SLIP_SMART
1002 /* drop keeptest bit = VSV */ 998 /* drop keeptest bit = VSV */
1003 if (test_bit(SLF_KEEPTEST, &sl->flags)) 999 if (test_bit(SLF_KEEPTEST, &sl->flags))
1004 clear_bit(SLF_KEEPTEST, &sl->flags); 1000 clear_bit(SLF_KEEPTEST, &sl->flags);
1005#endif 1001#endif
1006 1002
1007 if (!test_and_clear_bit(SLF_ERROR, &sl->flags) && (sl->rcount > 2)) { 1003 if (!test_and_clear_bit(SLF_ERROR, &sl->flags)
1004 && (sl->rcount > 2))
1008 sl_bump(sl); 1005 sl_bump(sl);
1009 }
1010 clear_bit(SLF_ESCAPE, &sl->flags); 1006 clear_bit(SLF_ESCAPE, &sl->flags);
1011 sl->rcount = 0; 1007 sl->rcount = 0;
1012 return; 1008 return;
1013 1009
1014 case ESC: 1010 case ESC:
1015 set_bit(SLF_ESCAPE, &sl->flags); 1011 set_bit(SLF_ESCAPE, &sl->flags);
1016 return; 1012 return;
1017 case ESC_ESC: 1013 case ESC_ESC:
1018 if (test_and_clear_bit(SLF_ESCAPE, &sl->flags)) { 1014 if (test_and_clear_bit(SLF_ESCAPE, &sl->flags))
1019 s = ESC; 1015 s = ESC;
1020 }
1021 break; 1016 break;
1022 case ESC_END: 1017 case ESC_END:
1023 if (test_and_clear_bit(SLF_ESCAPE, &sl->flags)) { 1018 if (test_and_clear_bit(SLF_ESCAPE, &sl->flags))
1024 s = END; 1019 s = END;
1025 }
1026 break; 1020 break;
1027 } 1021 }
1028 if (!test_bit(SLF_ERROR, &sl->flags)) { 1022 if (!test_bit(SLF_ERROR, &sl->flags)) {
@@ -1041,8 +1035,7 @@ static void slip_unesc(struct slip *sl, unsigned char s)
1041 * 6 BIT SLIP ENCAPSULATION * 1035 * 6 BIT SLIP ENCAPSULATION *
1042 ************************************************************************/ 1036 ************************************************************************/
1043 1037
1044int 1038static int slip_esc6(unsigned char *s, unsigned char *d, int len)
1045slip_esc6(unsigned char *s, unsigned char *d, int len)
1046{ 1039{
1047 unsigned char *ptr = d; 1040 unsigned char *ptr = d;
1048 unsigned char c; 1041 unsigned char c;
@@ -1079,8 +1072,7 @@ slip_esc6(unsigned char *s, unsigned char *d, int len)
1079 return ptr - d; 1072 return ptr - d;
1080} 1073}
1081 1074
1082void 1075static void slip_unesc6(struct slip *sl, unsigned char s)
1083slip_unesc6(struct slip *sl, unsigned char s)
1084{ 1076{
1085 unsigned char c; 1077 unsigned char c;
1086 1078
@@ -1091,13 +1083,13 @@ slip_unesc6(struct slip *sl, unsigned char s)
1091 clear_bit(SLF_KEEPTEST, &sl->flags); 1083 clear_bit(SLF_KEEPTEST, &sl->flags);
1092#endif 1084#endif
1093 1085
1094 if (!test_and_clear_bit(SLF_ERROR, &sl->flags) && (sl->rcount > 2)) { 1086 if (!test_and_clear_bit(SLF_ERROR, &sl->flags)
1087 && (sl->rcount > 2))
1095 sl_bump(sl); 1088 sl_bump(sl);
1096 }
1097 sl->rcount = 0; 1089 sl->rcount = 0;
1098 sl->xbits = 0; 1090 sl->xbits = 0;
1099 sl->xdata = 0; 1091 sl->xdata = 0;
1100 } else if (s >= 0x30 && s < 0x70) { 1092 } else if (s >= 0x30 && s < 0x70) {
1101 sl->xdata = (sl->xdata << 6) | ((s - 0x30) & 0x3F); 1093 sl->xdata = (sl->xdata << 6) | ((s - 0x30) & 0x3F);
1102 sl->xbits += 6; 1094 sl->xbits += 6;
1103 if (sl->xbits >= 8) { 1095 if (sl->xbits >= 8) {
@@ -1112,24 +1104,24 @@ slip_unesc6(struct slip *sl, unsigned char s)
1112 set_bit(SLF_ERROR, &sl->flags); 1104 set_bit(SLF_ERROR, &sl->flags);
1113 } 1105 }
1114 } 1106 }
1115 } 1107 }
1116} 1108}
1117#endif /* CONFIG_SLIP_MODE_SLIP6 */ 1109#endif /* CONFIG_SLIP_MODE_SLIP6 */
1118 1110
1119/* Perform I/O control on an active SLIP channel. */ 1111/* Perform I/O control on an active SLIP channel. */
1120static int slip_ioctl(struct tty_struct *tty, struct file *file, unsigned int cmd, unsigned long arg) 1112static int slip_ioctl(struct tty_struct *tty, struct file *file,
1113 unsigned int cmd, unsigned long arg)
1121{ 1114{
1122 struct slip *sl = (struct slip *) tty->disc_data; 1115 struct slip *sl = tty->disc_data;
1123 unsigned int tmp; 1116 unsigned int tmp;
1124 int __user *p = (int __user *)arg; 1117 int __user *p = (int __user *)arg;
1125 1118
1126 /* First make sure we're connected. */ 1119 /* First make sure we're connected. */
1127 if (!sl || sl->magic != SLIP_MAGIC) { 1120 if (!sl || sl->magic != SLIP_MAGIC)
1128 return -EINVAL; 1121 return -EINVAL;
1129 }
1130 1122
1131 switch(cmd) { 1123 switch (cmd) {
1132 case SIOCGIFNAME: 1124 case SIOCGIFNAME:
1133 tmp = strlen(sl->dev->name) + 1; 1125 tmp = strlen(sl->dev->name) + 1;
1134 if (copy_to_user((void __user *)arg, sl->dev->name, tmp)) 1126 if (copy_to_user((void __user *)arg, sl->dev->name, tmp))
1135 return -EFAULT; 1127 return -EFAULT;
@@ -1144,34 +1136,31 @@ static int slip_ioctl(struct tty_struct *tty, struct file *file, unsigned int cm
1144 if (get_user(tmp, p)) 1136 if (get_user(tmp, p))
1145 return -EFAULT; 1137 return -EFAULT;
1146#ifndef SL_INCLUDE_CSLIP 1138#ifndef SL_INCLUDE_CSLIP
1147 if (tmp & (SL_MODE_CSLIP|SL_MODE_ADAPTIVE)) { 1139 if (tmp & (SL_MODE_CSLIP|SL_MODE_ADAPTIVE))
1148 return -EINVAL; 1140 return -EINVAL;
1149 }
1150#else 1141#else
1151 if ((tmp & (SL_MODE_ADAPTIVE | SL_MODE_CSLIP)) == 1142 if ((tmp & (SL_MODE_ADAPTIVE | SL_MODE_CSLIP)) ==
1152 (SL_MODE_ADAPTIVE | SL_MODE_CSLIP)) { 1143 (SL_MODE_ADAPTIVE | SL_MODE_CSLIP))
1153 /* return -EINVAL; */ 1144 /* return -EINVAL; */
1154 tmp &= ~SL_MODE_ADAPTIVE; 1145 tmp &= ~SL_MODE_ADAPTIVE;
1155 }
1156#endif 1146#endif
1157#ifndef CONFIG_SLIP_MODE_SLIP6 1147#ifndef CONFIG_SLIP_MODE_SLIP6
1158 if (tmp & SL_MODE_SLIP6) { 1148 if (tmp & SL_MODE_SLIP6)
1159 return -EINVAL; 1149 return -EINVAL;
1160 }
1161#endif 1150#endif
1162 sl->mode = tmp; 1151 sl->mode = tmp;
1163 sl->dev->type = ARPHRD_SLIP+sl->mode; 1152 sl->dev->type = ARPHRD_SLIP + sl->mode;
1164 return 0; 1153 return 0;
1165 1154
1166 case SIOCSIFHWADDR: 1155 case SIOCSIFHWADDR:
1167 return -EINVAL; 1156 return -EINVAL;
1168 1157
1169#ifdef CONFIG_SLIP_SMART 1158#ifdef CONFIG_SLIP_SMART
1170 /* VSV changes start here */ 1159 /* VSV changes start here */
1171 case SIOCSKEEPALIVE: 1160 case SIOCSKEEPALIVE:
1172 if (get_user(tmp, p)) 1161 if (get_user(tmp, p))
1173 return -EFAULT; 1162 return -EFAULT;
1174 if (tmp > 255) /* max for unchar */ 1163 if (tmp > 255) /* max for unchar */
1175 return -EINVAL; 1164 return -EINVAL;
1176 1165
1177 spin_lock_bh(&sl->lock); 1166 spin_lock_bh(&sl->lock);
@@ -1179,40 +1168,42 @@ static int slip_ioctl(struct tty_struct *tty, struct file *file, unsigned int cm
1179 spin_unlock_bh(&sl->lock); 1168 spin_unlock_bh(&sl->lock);
1180 return -ENODEV; 1169 return -ENODEV;
1181 } 1170 }
1182 if ((sl->keepalive = (unchar) tmp) != 0) { 1171 sl->keepalive = (u8)tmp;
1183 mod_timer(&sl->keepalive_timer, jiffies+sl->keepalive*HZ); 1172 if (sl->keepalive != 0) {
1173 mod_timer(&sl->keepalive_timer,
1174 jiffies + sl->keepalive * HZ);
1184 set_bit(SLF_KEEPTEST, &sl->flags); 1175 set_bit(SLF_KEEPTEST, &sl->flags);
1185 } else { 1176 } else
1186 del_timer (&sl->keepalive_timer); 1177 del_timer(&sl->keepalive_timer);
1187 }
1188 spin_unlock_bh(&sl->lock); 1178 spin_unlock_bh(&sl->lock);
1189 return 0; 1179 return 0;
1190 1180
1191 case SIOCGKEEPALIVE: 1181 case SIOCGKEEPALIVE:
1192 if (put_user(sl->keepalive, p)) 1182 if (put_user(sl->keepalive, p))
1193 return -EFAULT; 1183 return -EFAULT;
1194 return 0; 1184 return 0;
1195 1185
1196 case SIOCSOUTFILL: 1186 case SIOCSOUTFILL:
1197 if (get_user(tmp, p)) 1187 if (get_user(tmp, p))
1198 return -EFAULT; 1188 return -EFAULT;
1199 if (tmp > 255) /* max for unchar */ 1189 if (tmp > 255) /* max for unchar */
1200 return -EINVAL; 1190 return -EINVAL;
1201 spin_lock_bh(&sl->lock); 1191 spin_lock_bh(&sl->lock);
1202 if (!sl->tty) { 1192 if (!sl->tty) {
1203 spin_unlock_bh(&sl->lock); 1193 spin_unlock_bh(&sl->lock);
1204 return -ENODEV; 1194 return -ENODEV;
1205 } 1195 }
1206 if ((sl->outfill = (unchar) tmp) != 0){ 1196 sl->outfill = (u8)tmp;
1207 mod_timer(&sl->outfill_timer, jiffies+sl->outfill*HZ); 1197 if (sl->outfill != 0) {
1198 mod_timer(&sl->outfill_timer,
1199 jiffies + sl->outfill * HZ);
1208 set_bit(SLF_OUTWAIT, &sl->flags); 1200 set_bit(SLF_OUTWAIT, &sl->flags);
1209 } else { 1201 } else
1210 del_timer (&sl->outfill_timer); 1202 del_timer(&sl->outfill_timer);
1211 }
1212 spin_unlock_bh(&sl->lock); 1203 spin_unlock_bh(&sl->lock);
1213 return 0; 1204 return 0;
1214 1205
1215 case SIOCGOUTFILL: 1206 case SIOCGOUTFILL:
1216 if (put_user(sl->outfill, p)) 1207 if (put_user(sl->outfill, p))
1217 return -EFAULT; 1208 return -EFAULT;
1218 return 0; 1209 return 0;
@@ -1229,7 +1220,7 @@ static int slip_ioctl(struct tty_struct *tty, struct file *file, unsigned int cm
1229 to allow get/set outfill/keepalive parameter 1220 to allow get/set outfill/keepalive parameter
1230 by ifconfig */ 1221 by ifconfig */
1231 1222
1232static int sl_ioctl(struct net_device *dev,struct ifreq *rq,int cmd) 1223static int sl_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
1233{ 1224{
1234 struct slip *sl = netdev_priv(dev); 1225 struct slip *sl = netdev_priv(dev);
1235 unsigned long *p = (unsigned long *)&rq->ifr_ifru; 1226 unsigned long *p = (unsigned long *)&rq->ifr_ifru;
@@ -1244,58 +1235,61 @@ static int sl_ioctl(struct net_device *dev,struct ifreq *rq,int cmd)
1244 return -ENODEV; 1235 return -ENODEV;
1245 } 1236 }
1246 1237
1247 switch(cmd){ 1238 switch (cmd) {
1248 case SIOCSKEEPALIVE: 1239 case SIOCSKEEPALIVE:
1249 /* max for unchar */ 1240 /* max for unchar */
1250 if ((unsigned)*p > 255) { 1241 if ((unsigned)*p > 255) {
1251 spin_unlock_bh(&sl->lock); 1242 spin_unlock_bh(&sl->lock);
1252 return -EINVAL; 1243 return -EINVAL;
1253 } 1244 }
1254 sl->keepalive = (unchar) *p; 1245 sl->keepalive = (u8)*p;
1255 if (sl->keepalive != 0) { 1246 if (sl->keepalive != 0) {
1256 sl->keepalive_timer.expires=jiffies+sl->keepalive*HZ; 1247 sl->keepalive_timer.expires =
1257 mod_timer(&sl->keepalive_timer, jiffies+sl->keepalive*HZ); 1248 jiffies + sl->keepalive * HZ;
1249 mod_timer(&sl->keepalive_timer,
1250 jiffies + sl->keepalive * HZ);
1258 set_bit(SLF_KEEPTEST, &sl->flags); 1251 set_bit(SLF_KEEPTEST, &sl->flags);
1259 } else { 1252 } else
1260 del_timer(&sl->keepalive_timer); 1253 del_timer(&sl->keepalive_timer);
1261 }
1262 break; 1254 break;
1263 1255
1264 case SIOCGKEEPALIVE: 1256 case SIOCGKEEPALIVE:
1265 *p = sl->keepalive; 1257 *p = sl->keepalive;
1266 break; 1258 break;
1267 1259
1268 case SIOCSOUTFILL: 1260 case SIOCSOUTFILL:
1269 if ((unsigned)*p > 255) { /* max for unchar */ 1261 if ((unsigned)*p > 255) { /* max for unchar */
1270 spin_unlock_bh(&sl->lock); 1262 spin_unlock_bh(&sl->lock);
1271 return -EINVAL; 1263 return -EINVAL;
1272 } 1264 }
1273 if ((sl->outfill = (unchar)*p) != 0){ 1265 sl->outfill = (u8)*p;
1274 mod_timer(&sl->outfill_timer, jiffies+sl->outfill*HZ); 1266 if (sl->outfill != 0) {
1267 mod_timer(&sl->outfill_timer,
1268 jiffies + sl->outfill * HZ);
1275 set_bit(SLF_OUTWAIT, &sl->flags); 1269 set_bit(SLF_OUTWAIT, &sl->flags);
1276 } else { 1270 } else
1277 del_timer (&sl->outfill_timer); 1271 del_timer(&sl->outfill_timer);
1278 } 1272 break;
1279 break;
1280 1273
1281 case SIOCGOUTFILL: 1274 case SIOCGOUTFILL:
1282 *p = sl->outfill; 1275 *p = sl->outfill;
1283 break; 1276 break;
1284 1277
1285 case SIOCSLEASE: 1278 case SIOCSLEASE:
1286 /* Resolve race condition, when ioctl'ing hanged up 1279 /* Resolve race condition, when ioctl'ing hanged up
1287 and opened by another process device. 1280 and opened by another process device.
1288 */ 1281 */
1289 if (sl->tty != current->signal->tty && sl->pid != current->pid) { 1282 if (sl->tty != current->signal->tty &&
1283 sl->pid != current->pid) {
1290 spin_unlock_bh(&sl->lock); 1284 spin_unlock_bh(&sl->lock);
1291 return -EPERM; 1285 return -EPERM;
1292 } 1286 }
1293 sl->leased = 0; 1287 sl->leased = 0;
1294 if (*p) 1288 if (*p)
1295 sl->leased = 1; 1289 sl->leased = 1;
1296 break; 1290 break;
1297 1291
1298 case SIOCGLEASE: 1292 case SIOCGLEASE:
1299 *p = sl->leased; 1293 *p = sl->leased;
1300 }; 1294 };
1301 spin_unlock_bh(&sl->lock); 1295 spin_unlock_bh(&sl->lock);
@@ -1327,7 +1321,7 @@ static int __init slip_init(void)
1327 " (6 bit encapsulation enabled)" 1321 " (6 bit encapsulation enabled)"
1328#endif 1322#endif
1329 ".\n", 1323 ".\n",
1330 SLIP_VERSION, slip_maxdev ); 1324 SLIP_VERSION, slip_maxdev);
1331#if defined(SL_INCLUDE_CSLIP) 1325#if defined(SL_INCLUDE_CSLIP)
1332 printk(KERN_INFO "CSLIP: code copyright 1989 Regents of the University of California.\n"); 1326 printk(KERN_INFO "CSLIP: code copyright 1989 Regents of the University of California.\n");
1333#endif 1327#endif
@@ -1335,14 +1329,16 @@ static int __init slip_init(void)
1335 printk(KERN_INFO "SLIP linefill/keepalive option.\n"); 1329 printk(KERN_INFO "SLIP linefill/keepalive option.\n");
1336#endif 1330#endif
1337 1331
1338 slip_devs = kzalloc(sizeof(struct net_device *)*slip_maxdev, GFP_KERNEL); 1332 slip_devs = kzalloc(sizeof(struct net_device *)*slip_maxdev,
1333 GFP_KERNEL);
1339 if (!slip_devs) { 1334 if (!slip_devs) {
1340 printk(KERN_ERR "SLIP: Can't allocate slip devices array! Uaargh! (-> No SLIP available)\n"); 1335 printk(KERN_ERR "SLIP: Can't allocate slip devices array.\n");
1341 return -ENOMEM; 1336 return -ENOMEM;
1342 } 1337 }
1343 1338
1344 /* Fill in our line protocol discipline, and register it */ 1339 /* Fill in our line protocol discipline, and register it */
1345 if ((status = tty_register_ldisc(N_SLIP, &sl_ldisc)) != 0) { 1340 status = tty_register_ldisc(N_SLIP, &sl_ldisc);
1341 if (status != 0) {
1346 printk(KERN_ERR "SLIP: can't register line discipline (err = %d)\n", status); 1342 printk(KERN_ERR "SLIP: can't register line discipline (err = %d)\n", status);
1347 kfree(slip_devs); 1343 kfree(slip_devs);
1348 } 1344 }
@@ -1402,10 +1398,9 @@ static void __exit slip_exit(void)
1402 kfree(slip_devs); 1398 kfree(slip_devs);
1403 slip_devs = NULL; 1399 slip_devs = NULL;
1404 1400
1405 if ((i = tty_unregister_ldisc(N_SLIP))) 1401 i = tty_unregister_ldisc(N_SLIP);
1406 { 1402 if (i != 0)
1407 printk(KERN_ERR "SLIP: can't unregister line discipline (err = %d)\n", i); 1403 printk(KERN_ERR "SLIP: can't unregister line discipline (err = %d)\n", i);
1408 }
1409} 1404}
1410 1405
1411module_init(slip_init); 1406module_init(slip_init);
@@ -1419,17 +1414,15 @@ module_exit(slip_exit);
1419 1414
1420static void sl_outfill(unsigned long sls) 1415static void sl_outfill(unsigned long sls)
1421{ 1416{
1422 struct slip *sl=(struct slip *)sls; 1417 struct slip *sl = (struct slip *)sls;
1423 1418
1424 spin_lock(&sl->lock); 1419 spin_lock(&sl->lock);
1425 1420
1426 if (sl->tty == NULL) 1421 if (sl->tty == NULL)
1427 goto out; 1422 goto out;
1428 1423
1429 if(sl->outfill) 1424 if (sl->outfill) {
1430 { 1425 if (test_bit(SLF_OUTWAIT, &sl->flags)) {
1431 if( test_bit(SLF_OUTWAIT, &sl->flags) )
1432 {
1433 /* no packets were transmitted, do outfill */ 1426 /* no packets were transmitted, do outfill */
1434#ifdef CONFIG_SLIP_MODE_SLIP6 1427#ifdef CONFIG_SLIP_MODE_SLIP6
1435 unsigned char s = (sl->mode & SL_MODE_SLIP6)?0x70:END; 1428 unsigned char s = (sl->mode & SL_MODE_SLIP6)?0x70:END;
@@ -1437,13 +1430,11 @@ static void sl_outfill(unsigned long sls)
1437 unsigned char s = END; 1430 unsigned char s = END;
1438#endif 1431#endif
1439 /* put END into tty queue. Is it right ??? */ 1432 /* put END into tty queue. Is it right ??? */
1440 if (!netif_queue_stopped(sl->dev)) 1433 if (!netif_queue_stopped(sl->dev)) {
1441 {
1442 /* if device busy no outfill */ 1434 /* if device busy no outfill */
1443 sl->tty->driver->write(sl->tty, &s, 1); 1435 sl->tty->driver->write(sl->tty, &s, 1);
1444 } 1436 }
1445 } 1437 } else
1446 else
1447 set_bit(SLF_OUTWAIT, &sl->flags); 1438 set_bit(SLF_OUTWAIT, &sl->flags);
1448 1439
1449 mod_timer(&sl->outfill_timer, jiffies+sl->outfill*HZ); 1440 mod_timer(&sl->outfill_timer, jiffies+sl->outfill*HZ);
@@ -1454,31 +1445,29 @@ out:
1454 1445
1455static void sl_keepalive(unsigned long sls) 1446static void sl_keepalive(unsigned long sls)
1456{ 1447{
1457 struct slip *sl=(struct slip *)sls; 1448 struct slip *sl = (struct slip *)sls;
1458 1449
1459 spin_lock(&sl->lock); 1450 spin_lock(&sl->lock);
1460 1451
1461 if (sl->tty == NULL) 1452 if (sl->tty == NULL)
1462 goto out; 1453 goto out;
1463 1454
1464 if( sl->keepalive) 1455 if (sl->keepalive) {
1465 { 1456 if (test_bit(SLF_KEEPTEST, &sl->flags)) {
1466 if(test_bit(SLF_KEEPTEST, &sl->flags))
1467 {
1468 /* keepalive still high :(, we must hangup */ 1457 /* keepalive still high :(, we must hangup */
1469 if( sl->outfill ) /* outfill timer must be deleted too */ 1458 if (sl->outfill)
1459 /* outfill timer must be deleted too */
1470 (void)del_timer(&sl->outfill_timer); 1460 (void)del_timer(&sl->outfill_timer);
1471 printk(KERN_DEBUG "%s: no packets received during keepalive timeout, hangup.\n", sl->dev->name); 1461 printk(KERN_DEBUG "%s: no packets received during keepalive timeout, hangup.\n", sl->dev->name);
1472 tty_hangup(sl->tty); /* this must hangup tty & close slip */ 1462 /* this must hangup tty & close slip */
1463 tty_hangup(sl->tty);
1473 /* I think we need not something else */ 1464 /* I think we need not something else */
1474 goto out; 1465 goto out;
1475 } 1466 } else
1476 else
1477 set_bit(SLF_KEEPTEST, &sl->flags); 1467 set_bit(SLF_KEEPTEST, &sl->flags);
1478 1468
1479 mod_timer(&sl->keepalive_timer, jiffies+sl->keepalive*HZ); 1469 mod_timer(&sl->keepalive_timer, jiffies+sl->keepalive*HZ);
1480 } 1470 }
1481
1482out: 1471out:
1483 spin_unlock(&sl->lock); 1472 spin_unlock(&sl->lock);
1484} 1473}