1 /* $Id: isdn_ppp.c,v 1.1.2.3 2004/02/10 01:07:13 keil Exp $
 
   3  * Linux ISDN subsystem, functions for synchronous PPP (linklevel).
 
   5  * Copyright 1995,96 by Michael Hipp (Michael.Hipp@student.uni-tuebingen.de)
 
   7  * This software may be used and distributed according to the terms
 
   8  * of the GNU General Public License, incorporated herein by reference.
 
  12 #include <linux/isdn.h>
 
  13 #include <linux/poll.h>
 
  14 #include <linux/ppp-comp.h>
 
  15 #ifdef CONFIG_IPPP_FILTER
 
  16 #include <linux/filter.h>
 
  19 #include "isdn_common.h"
 
  24 #define PPP_IPX 0x002b
 
  28 static int isdn_ppp_fill_rq(unsigned char *buf, int len, int proto, int slot);
 
  29 static int isdn_ppp_closewait(int slot);
 
  30 static void isdn_ppp_push_higher(isdn_net_dev * net_dev, isdn_net_local * lp,
 
  31                                  struct sk_buff *skb, int proto);
 
  32 static int isdn_ppp_if_get_unit(char *namebuf);
 
  33 static int isdn_ppp_set_compressor(struct ippp_struct *is,struct isdn_ppp_comp_data *);
 
  34 static struct sk_buff *isdn_ppp_decompress(struct sk_buff *,
 
  35                                 struct ippp_struct *,struct ippp_struct *,int *proto);
 
  36 static void isdn_ppp_receive_ccp(isdn_net_dev * net_dev, isdn_net_local * lp,
 
  37                                 struct sk_buff *skb,int proto);
 
  38 static struct sk_buff *isdn_ppp_compress(struct sk_buff *skb_in,int *proto,
 
  39         struct ippp_struct *is,struct ippp_struct *master,int type);
 
  40 static void isdn_ppp_send_ccp(isdn_net_dev *net_dev, isdn_net_local *lp,
 
  44 static void isdn_ppp_ccp_kickup(struct ippp_struct *is);
 
  45 static void isdn_ppp_ccp_xmit_reset(struct ippp_struct *is, int proto,
 
  46                                     unsigned char code, unsigned char id,
 
  47                                     unsigned char *data, int len);
 
  48 static struct ippp_ccp_reset *isdn_ppp_ccp_reset_alloc(struct ippp_struct *is);
 
  49 static void isdn_ppp_ccp_reset_free(struct ippp_struct *is);
 
  50 static void isdn_ppp_ccp_reset_free_state(struct ippp_struct *is,
 
  52 static void isdn_ppp_ccp_timer_callback(unsigned long closure);
 
  53 static struct ippp_ccp_reset_state *isdn_ppp_ccp_reset_alloc_state(struct ippp_struct *is,
 
  55 static void isdn_ppp_ccp_reset_trans(struct ippp_struct *is,
 
  56                                      struct isdn_ppp_resetparams *rp);
 
  57 static void isdn_ppp_ccp_reset_ack_rcvd(struct ippp_struct *is,
 
  62 #ifdef CONFIG_ISDN_MPP
 
  63 static ippp_bundle * isdn_ppp_bundle_arr = NULL;
 
  65 static int isdn_ppp_mp_bundle_array_init(void);
 
  66 static int isdn_ppp_mp_init( isdn_net_local * lp, ippp_bundle * add_to );
 
  67 static void isdn_ppp_mp_receive(isdn_net_dev * net_dev, isdn_net_local * lp, 
 
  69 static void isdn_ppp_mp_cleanup( isdn_net_local * lp );
 
  71 static int isdn_ppp_bundle(struct ippp_struct *, int unit);
 
  72 #endif  /* CONFIG_ISDN_MPP */
 
  74 char *isdn_ppp_revision = "$Revision: 1.1.2.3 $";
 
  76 static struct ippp_struct *ippp_table[ISDN_MAX_CHANNELS];
 
  78 static struct isdn_ppp_compressor *ipc_head = NULL;
 
  84 isdn_ppp_frame_log(char *info, char *data, int len, int maxlen,int unit,int slot)
 
  94         for (i = 0, cnt = 0; cnt < maxlen; i++) {
 
  95                 for (j = 0; j < 16 && cnt < maxlen; j++, cnt++)
 
  96                         sprintf(buf + j * 3, "%02x ", (unsigned char) data[cnt]);
 
  97                 printk(KERN_DEBUG "[%d/%d].%s[%d]: %s\n",unit,slot, info, i, buf);
 
 102  * unbind isdn_net_local <=> ippp-device
 
 103  * note: it can happen, that we hangup/free the master before the slaves
 
 104  *       in this case we bind another lp to the master device
 
 107 isdn_ppp_free(isdn_net_local * lp)
 
 109         struct ippp_struct *is;
 
 111         if (lp->ppp_slot < 0 || lp->ppp_slot >= ISDN_MAX_CHANNELS) {
 
 112                 printk(KERN_ERR "%s: ppp_slot(%d) out of range\n",
 
 113                         __func__, lp->ppp_slot);
 
 117 #ifdef CONFIG_ISDN_MPP
 
 118         spin_lock(&lp->netdev->pb->lock);
 
 120         isdn_net_rm_from_bundle(lp);
 
 121 #ifdef CONFIG_ISDN_MPP
 
 122         if (lp->netdev->pb->ref_ct == 1)        /* last link in queue? */
 
 123                 isdn_ppp_mp_cleanup(lp);
 
 125         lp->netdev->pb->ref_ct--;
 
 126         spin_unlock(&lp->netdev->pb->lock);
 
 127 #endif /* CONFIG_ISDN_MPP */
 
 128         if (lp->ppp_slot < 0 || lp->ppp_slot >= ISDN_MAX_CHANNELS) {
 
 129                 printk(KERN_ERR "%s: ppp_slot(%d) now invalid\n",
 
 130                         __func__, lp->ppp_slot);
 
 133         is = ippp_table[lp->ppp_slot];
 
 134         if ((is->state & IPPP_CONNECT))
 
 135                 isdn_ppp_closewait(lp->ppp_slot);       /* force wakeup on ippp device */
 
 136         else if (is->state & IPPP_ASSIGNED)
 
 137                 is->state = IPPP_OPEN;  /* fallback to 'OPEN but not ASSIGNED' state */
 
 140                 printk(KERN_DEBUG "isdn_ppp_free %d %lx %lx\n", lp->ppp_slot, (long) lp, (long) is->lp);
 
 142         is->lp = NULL;          /* link is down .. set lp to NULL */
 
 143         lp->ppp_slot = -1;      /* is this OK ?? */
 
 149  * bind isdn_net_local <=> ippp-device
 
 151  * This function is allways called with holding dev->lock so
 
 152  * no additional lock is needed
 
 155 isdn_ppp_bind(isdn_net_local * lp)
 
 159         struct ippp_struct *is;
 
 162         if (lp->pppbind < 0) {  /* device bounded to ippp device ? */
 
 163                 isdn_net_dev *net_dev = dev->netdev;
 
 164                 char exclusive[ISDN_MAX_CHANNELS];      /* exclusive flags */
 
 165                 memset(exclusive, 0, ISDN_MAX_CHANNELS);
 
 166                 while (net_dev) {       /* step through net devices to find exclusive minors */
 
 167                         isdn_net_local *lp = net_dev->local;
 
 168                         if (lp->pppbind >= 0)
 
 169                                 exclusive[lp->pppbind] = 1;
 
 170                         net_dev = net_dev->next;
 
 173                  * search a free device / slot
 
 175                 for (i = 0; i < ISDN_MAX_CHANNELS; i++) {
 
 176                         if (ippp_table[i]->state == IPPP_OPEN && !exclusive[ippp_table[i]->minor]) {    /* OPEN, but not connected! */
 
 181                 for (i = 0; i < ISDN_MAX_CHANNELS; i++) {
 
 182                         if (ippp_table[i]->minor == lp->pppbind &&
 
 183                             (ippp_table[i]->state & IPPP_OPEN) == IPPP_OPEN)
 
 188         if (i >= ISDN_MAX_CHANNELS) {
 
 189                 printk(KERN_WARNING "isdn_ppp_bind: Can't find a (free) connection to the ipppd daemon.\n");
 
 193         /* get unit number from interface name .. ugly! */
 
 194         unit = isdn_ppp_if_get_unit(lp->netdev->dev->name);
 
 196                 printk(KERN_ERR "isdn_ppp_bind: illegal interface name %s.\n",
 
 197                         lp->netdev->dev->name);
 
 206         is->state = IPPP_OPEN | IPPP_ASSIGNED;  /* assigned to a netdevice but not connected */
 
 207 #ifdef CONFIG_ISDN_MPP
 
 208         retval = isdn_ppp_mp_init(lp, NULL);
 
 211 #endif /* CONFIG_ISDN_MPP */
 
 213         retval = lp->ppp_slot;
 
 220  * kick the ipppd on the device
 
 221  * (wakes up daemon after B-channel connect)
 
 225 isdn_ppp_wakeup_daemon(isdn_net_local * lp)
 
 227         if (lp->ppp_slot < 0 || lp->ppp_slot >= ISDN_MAX_CHANNELS) {
 
 228                 printk(KERN_ERR "%s: ppp_slot(%d) out of range\n",
 
 229                         __func__, lp->ppp_slot);
 
 232         ippp_table[lp->ppp_slot]->state = IPPP_OPEN | IPPP_CONNECT | IPPP_NOBLOCK;
 
 233         wake_up_interruptible(&ippp_table[lp->ppp_slot]->wq);
 
 237  * there was a hangup on the netdevice
 
 238  * force wakeup of the ippp device
 
 239  * go into 'device waits for release' state
 
 242 isdn_ppp_closewait(int slot)
 
 244         struct ippp_struct *is;
 
 246         if (slot < 0 || slot >= ISDN_MAX_CHANNELS) {
 
 247                 printk(KERN_ERR "%s: slot(%d) out of range\n",
 
 251         is = ippp_table[slot];
 
 253                 wake_up_interruptible(&is->wq);
 
 254         is->state = IPPP_CLOSEWAIT;
 
 259  * isdn_ppp_find_slot / isdn_ppp_free_slot
 
 263 isdn_ppp_get_slot(void)
 
 266         for (i = 0; i < ISDN_MAX_CHANNELS; i++) {
 
 267                 if (!ippp_table[i]->state)
 
 278 isdn_ppp_open(int min, struct file *file)
 
 281         struct ippp_struct *is;
 
 283         if (min < 0 || min >= ISDN_MAX_CHANNELS)
 
 286         slot = isdn_ppp_get_slot();
 
 290         is = file->private_data = ippp_table[slot];
 
 292         printk(KERN_DEBUG "ippp, open, slot: %d, minor: %d, state: %04x\n",
 
 293                slot, min, is->state);
 
 295         /* compression stuff */
 
 296         is->link_compressor   = is->compressor = NULL;
 
 297         is->link_decompressor = is->decompressor = NULL;
 
 298         is->link_comp_stat    = is->comp_stat = NULL;
 
 299         is->link_decomp_stat  = is->decomp_stat = NULL;
 
 302         is->reset = isdn_ppp_ccp_reset_alloc(is);
 
 305         is->mp_seqno = 0;       /* MP sequence number */
 
 306         is->pppcfg = 0;         /* ppp configuration */
 
 307         is->mpppcfg = 0;        /* mppp configuration */
 
 308         is->last_link_seqno = -1;       /* MP: maybe set to Bundle-MIN, when joining a bundle ?? */
 
 309         is->unit = -1;          /* set, when we have our interface */
 
 310         is->mru = 1524;         /* MRU, default 1524 */
 
 311         is->maxcid = 16;        /* VJ: maxcid */
 
 313         init_waitqueue_head(&is->wq);
 
 314         is->first = is->rq + NUM_RCV_BUFFS - 1; /* receive queue */
 
 317 #ifdef CONFIG_ISDN_PPP_VJ
 
 319          * VJ header compression init
 
 321         is->slcomp = slhc_init(16, 16); /* not necessary for 2. link in bundle */
 
 323 #ifdef CONFIG_IPPP_FILTER
 
 324         is->pass_filter = NULL;
 
 325         is->active_filter = NULL;
 
 327         is->state = IPPP_OPEN;
 
 333  * release ippp device
 
 336 isdn_ppp_release(int min, struct file *file)
 
 339         struct ippp_struct *is;
 
 341         if (min < 0 || min >= ISDN_MAX_CHANNELS)
 
 343         is = file->private_data;
 
 346                 printk(KERN_ERR "%s: no file->private_data\n", __func__);
 
 350                 printk(KERN_DEBUG "ippp: release, minor: %d %lx\n", min, (long) is->lp);
 
 352         if (is->lp) {           /* a lp address says: this link is still up */
 
 353                 isdn_net_dev *p = is->lp->netdev;
 
 356                         printk(KERN_ERR "%s: no lp->netdev\n", __func__);
 
 359                 is->state &= ~IPPP_CONNECT;     /* -> effect: no call of wakeup */
 
 361                  * isdn_net_hangup() calls isdn_ppp_free()
 
 362                  * isdn_ppp_free() sets is->lp to NULL and lp->ppp_slot to -1
 
 363                  * removing the IPPP_CONNECT flag omits calling of isdn_ppp_wakeup_daemon()
 
 365                 isdn_net_hangup(p->dev);
 
 367         for (i = 0; i < NUM_RCV_BUFFS; i++) {
 
 368                 kfree(is->rq[i].buf);
 
 369                 is->rq[i].buf = NULL;
 
 371         is->first = is->rq + NUM_RCV_BUFFS - 1; /* receive queue */
 
 374 #ifdef CONFIG_ISDN_PPP_VJ
 
 375 /* TODO: if this was the previous master: link the slcomp to the new master */
 
 376         slhc_free(is->slcomp);
 
 379 #ifdef CONFIG_IPPP_FILTER
 
 380         kfree(is->pass_filter);
 
 381         is->pass_filter = NULL;
 
 382         kfree(is->active_filter);
 
 383         is->active_filter = NULL;
 
 386 /* TODO: if this was the previous master: link the stuff to the new master */
 
 388                 is->compressor->free(is->comp_stat);
 
 389         if(is->link_comp_stat)
 
 390                 is->link_compressor->free(is->link_comp_stat);
 
 391         if(is->link_decomp_stat)
 
 392                 is->link_decompressor->free(is->link_decomp_stat);
 
 394                 is->decompressor->free(is->decomp_stat);
 
 395         is->compressor   = is->link_compressor   = NULL;
 
 396         is->decompressor = is->link_decompressor = NULL;
 
 397         is->comp_stat    = is->link_comp_stat    = NULL;
 
 398         is->decomp_stat  = is->link_decomp_stat  = NULL;
 
 400         /* Clean up if necessary */
 
 402                 isdn_ppp_ccp_reset_free(is);
 
 404         /* this slot is ready for new connections */
 
 409  * get_arg .. ioctl helper
 
 412 get_arg(void __user *b, void *val, int len)
 
 415                 len = sizeof(void *);
 
 416         if (copy_from_user(val, b, len))
 
 422  * set arg .. ioctl helper
 
 425 set_arg(void __user *b, void *val,int len)
 
 428                 len = sizeof(void *);
 
 429         if (copy_to_user(b, val, len))
 
 434 static int get_filter(void __user *arg, struct sock_filter **p)
 
 436         struct sock_fprog uprog;
 
 437         struct sock_filter *code = NULL;
 
 440         if (copy_from_user(&uprog, arg, sizeof(uprog)))
 
 448         /* uprog.len is unsigned short, so no overflow here */
 
 449         len = uprog.len * sizeof(struct sock_filter);
 
 450         code = kmalloc(len, GFP_KERNEL);
 
 454         if (copy_from_user(code, uprog.filter, len)) {
 
 459         err = sk_chk_filter(code, uprog.len);
 
 473 isdn_ppp_ioctl(int min, struct file *file, unsigned int cmd, unsigned long arg)
 
 477         struct ippp_struct *is;
 
 479         struct isdn_ppp_comp_data data;
 
 480         void __user *argp = (void __user *)arg;
 
 482         is = (struct ippp_struct *) file->private_data;
 
 486                 printk(KERN_DEBUG "isdn_ppp_ioctl: minor: %d cmd: %x state: %x\n", min, cmd, is->state);
 
 488         if (!(is->state & IPPP_OPEN))
 
 493 #ifdef CONFIG_ISDN_MPP
 
 494                         if (!(is->state & IPPP_CONNECT))
 
 496                         if ((r = get_arg(argp, &val, sizeof(val) )))
 
 498                         printk(KERN_DEBUG "iPPP-bundle: minor: %d, slave unit: %d, master unit: %d\n",
 
 499                                (int) min, (int) is->unit, (int) val);
 
 500                         return isdn_ppp_bundle(is, val);
 
 505                 case PPPIOCGUNIT:       /* get ppp/isdn unit number */
 
 506                         if ((r = set_arg(argp, &is->unit, sizeof(is->unit) )))
 
 512                         if ((r = set_arg(argp, lp->netdev->dev->name,
 
 513                                 strlen(lp->netdev->dev->name))))
 
 516                 case PPPIOCGMPFLAGS:    /* get configuration flags */
 
 517                         if ((r = set_arg(argp, &is->mpppcfg, sizeof(is->mpppcfg) )))
 
 520                 case PPPIOCSMPFLAGS:    /* set configuration flags */
 
 521                         if ((r = get_arg(argp, &val, sizeof(val) )))
 
 525                 case PPPIOCGFLAGS:      /* get configuration flags */
 
 526                         if ((r = set_arg(argp, &is->pppcfg,sizeof(is->pppcfg) )))
 
 529                 case PPPIOCSFLAGS:      /* set configuration flags */
 
 530                         if ((r = get_arg(argp, &val, sizeof(val) ))) {
 
 533                         if (val & SC_ENABLE_IP && !(is->pppcfg & SC_ENABLE_IP) && (is->state & IPPP_CONNECT)) {
 
 535                                         /* OK .. we are ready to send buffers */
 
 536                                         is->pppcfg = val; /* isdn_ppp_xmit test for SC_ENABLE_IP !!! */
 
 537                                         netif_wake_queue(lp->netdev->dev);
 
 543                 case PPPIOCGIDLE:       /* get idle time information */
 
 545                                 struct ppp_idle pidle;
 
 546                                 pidle.xmit_idle = pidle.recv_idle = lp->huptimer;
 
 547                                 if ((r = set_arg(argp, &pidle,sizeof(struct ppp_idle))))
 
 551                 case PPPIOCSMRU:        /* set receive unit size for PPP */
 
 552                         if ((r = get_arg(argp, &val, sizeof(val) )))
 
 560                 case PPPIOCSMAXCID:     /* set the maximum compression slot id */
 
 561                         if ((r = get_arg(argp, &val, sizeof(val) )))
 
 564                         if (is->maxcid != val) {
 
 565 #ifdef CONFIG_ISDN_PPP_VJ
 
 566                                 struct slcompress *sltmp;
 
 569                                         printk(KERN_DEBUG "ippp, ioctl: changed MAXCID to %ld\n", val);
 
 571 #ifdef CONFIG_ISDN_PPP_VJ
 
 572                                 sltmp = slhc_init(16, val);
 
 574                                         printk(KERN_ERR "ippp, can't realloc slhc struct\n");
 
 578                                         slhc_free(is->slcomp);
 
 584                         if ((r = set_arg(argp, &is->debug, sizeof(is->debug) )))
 
 588                         if ((r = get_arg(argp, &val, sizeof(val) )))
 
 592                 case PPPIOCGCOMPRESSORS:
 
 594                                 unsigned long protos[8] = {0,};
 
 595                                 struct isdn_ppp_compressor *ipc = ipc_head;
 
 597                                         j = ipc->num / (sizeof(long)*8);
 
 598                                         i = ipc->num % (sizeof(long)*8);
 
 600                                                 protos[j] |= (0x1<<i);
 
 603                                 if ((r = set_arg(argp,protos,8*sizeof(long) )))
 
 607                 case PPPIOCSCOMPRESSOR:
 
 608                         if ((r = get_arg(argp, &data, sizeof(struct isdn_ppp_comp_data))))
 
 610                         return isdn_ppp_set_compressor(is, &data);
 
 611                 case PPPIOCGCALLINFO:
 
 613                                 struct pppcallinfo pci;
 
 614                                 memset((char *) &pci,0,sizeof(struct pppcallinfo));
 
 617                                         strncpy(pci.local_num,lp->msn,63);
 
 619                                                 strncpy(pci.remote_num,lp->dial->num,63);
 
 621                                         pci.charge_units = lp->charge;
 
 623                                                 pci.calltype = CALLTYPE_OUTGOING;
 
 625                                                 pci.calltype = CALLTYPE_INCOMING;
 
 626                                         if(lp->flags & ISDN_NET_CALLBACK)
 
 627                                                 pci.calltype |= CALLTYPE_CALLBACK;
 
 629                                 return set_arg(argp,&pci,sizeof(struct pppcallinfo));
 
 631 #ifdef CONFIG_IPPP_FILTER
 
 634                                 struct sock_filter *code;
 
 635                                 int len = get_filter(argp, &code);
 
 638                                 kfree(is->pass_filter);
 
 639                                 is->pass_filter = code;
 
 645                                 struct sock_filter *code;
 
 646                                 int len = get_filter(argp, &code);
 
 649                                 kfree(is->active_filter);
 
 650                                 is->active_filter = code;
 
 651                                 is->active_len = len;
 
 654 #endif /* CONFIG_IPPP_FILTER */
 
 662 isdn_ppp_poll(struct file *file, poll_table * wait)
 
 665         struct ippp_buf_queue *bf, *bl;
 
 667         struct ippp_struct *is;
 
 669         is = file->private_data;
 
 672                 printk(KERN_DEBUG "isdn_ppp_poll: minor: %d\n",
 
 673                                 iminor(file->f_path.dentry->d_inode));
 
 675         /* just registers wait_queue hook. This doesn't really wait. */
 
 676         poll_wait(file, &is->wq, wait);
 
 678         if (!(is->state & IPPP_OPEN)) {
 
 679                 if(is->state == IPPP_CLOSEWAIT)
 
 681                 printk(KERN_DEBUG "isdn_ppp: device not open\n");
 
 684         /* we're always ready to send .. */
 
 685         mask = POLLOUT | POLLWRNORM;
 
 687         spin_lock_irqsave(&is->buflock, flags);
 
 691          * if IPPP_NOBLOCK is set we return even if we have nothing to read
 
 693         if (bf->next != bl || (is->state & IPPP_NOBLOCK)) {
 
 694                 is->state &= ~IPPP_NOBLOCK;
 
 695                 mask |= POLLIN | POLLRDNORM;
 
 697         spin_unlock_irqrestore(&is->buflock, flags);
 
 702  *  fill up isdn_ppp_read() queue ..
 
 706 isdn_ppp_fill_rq(unsigned char *buf, int len, int proto, int slot)
 
 708         struct ippp_buf_queue *bf, *bl;
 
 711         struct ippp_struct *is;
 
 713         if (slot < 0 || slot >= ISDN_MAX_CHANNELS) {
 
 714                 printk(KERN_WARNING "ippp: illegal slot(%d).\n", slot);
 
 717         is = ippp_table[slot];
 
 719         if (!(is->state & IPPP_CONNECT)) {
 
 720                 printk(KERN_DEBUG "ippp: device not activated.\n");
 
 723         nbuf = kmalloc(len + 4, GFP_ATOMIC);
 
 725                 printk(KERN_WARNING "ippp: Can't alloc buf\n");
 
 728         nbuf[0] = PPP_ALLSTATIONS;
 
 730         nbuf[2] = proto >> 8;
 
 731         nbuf[3] = proto & 0xff;
 
 732         memcpy(nbuf + 4, buf, len);
 
 734         spin_lock_irqsave(&is->buflock, flags);
 
 739                 printk(KERN_WARNING "ippp: Queue is full; discarding first buffer\n");
 
 744         bl->buf = (char *) nbuf;
 
 748         spin_unlock_irqrestore(&is->buflock, flags);
 
 749         wake_up_interruptible(&is->wq);
 
 754  * read() .. non-blocking: ipppd calls it only after select()
 
 755  *           reports, that there is data
 
 759 isdn_ppp_read(int min, struct file *file, char __user *buf, int count)
 
 761         struct ippp_struct *is;
 
 762         struct ippp_buf_queue *b;
 
 766         is = file->private_data;
 
 768         if (!(is->state & IPPP_OPEN))
 
 771         if (!access_ok(VERIFY_WRITE, buf, count))
 
 774         spin_lock_irqsave(&is->buflock, flags);
 
 778                 spin_unlock_irqrestore(&is->buflock, flags);
 
 786         spin_unlock_irqrestore(&is->buflock, flags);
 
 787         if (copy_to_user(buf, save_buf, count))
 
 795  * ipppd wanna write a packet to the card .. non-blocking
 
 799 isdn_ppp_write(int min, struct file *file, const char __user *buf, int count)
 
 802         struct ippp_struct *is;
 
 804         unsigned char protobuf[4];
 
 806         is = file->private_data;
 
 808         if (!(is->state & IPPP_CONNECT))
 
 813         /* -> push it directly to the lowlevel interface */
 
 816                 printk(KERN_DEBUG "isdn_ppp_write: lp == NULL\n");
 
 819                  * Don't reset huptimer for
 
 820                  * LCP packets. (Echo requests).
 
 822                 if (copy_from_user(protobuf, buf, 4))
 
 824                 proto = PPP_PROTOCOL(protobuf);
 
 825                 if (proto != PPP_LCP)
 
 828                 if (lp->isdn_device < 0 || lp->isdn_channel < 0)
 
 831                 if ((dev->drv[lp->isdn_device]->flags & DRV_FLAG_RUNNING) &&
 
 832                         lp->dialstate == 0 &&
 
 833                     (lp->flags & ISDN_NET_CONNECTED)) {
 
 837                          * we need to reserve enought space in front of
 
 838                          * sk_buff. old call to dev_alloc_skb only reserved
 
 839                          * 16 bytes, now we are looking what the driver want
 
 841                         hl = dev->drv[lp->isdn_device]->interface->hl_hdrlen;
 
 842                         skb = alloc_skb(hl+count, GFP_ATOMIC);
 
 844                                 printk(KERN_WARNING "isdn_ppp_write: out of memory!\n");
 
 847                         skb_reserve(skb, hl);
 
 848                         if (copy_from_user(skb_put(skb, count), buf, count))
 
 853                         if (is->debug & 0x40) {
 
 854                                 printk(KERN_DEBUG "ppp xmit: len %d\n", (int) skb->len);
 
 855                                 isdn_ppp_frame_log("xmit", skb->data, skb->len, 32,is->unit,lp->ppp_slot);
 
 858                         isdn_ppp_send_ccp(lp->netdev,lp,skb); /* keeps CCP/compression states in sync */
 
 860                         isdn_net_write_super(lp, skb);
 
 867  * init memory, structures etc.
 
 876 #ifdef CONFIG_ISDN_MPP
 
 877         if( isdn_ppp_mp_bundle_array_init() < 0 )
 
 879 #endif /* CONFIG_ISDN_MPP */
 
 881         for (i = 0; i < ISDN_MAX_CHANNELS; i++) {
 
 882                 if (!(ippp_table[i] = kzalloc(sizeof(struct ippp_struct), GFP_KERNEL))) {
 
 883                         printk(KERN_WARNING "isdn_ppp_init: Could not alloc ippp_table\n");
 
 884                         for (j = 0; j < i; j++)
 
 885                                 kfree(ippp_table[j]);
 
 888                 spin_lock_init(&ippp_table[i]->buflock);
 
 889                 ippp_table[i]->state = 0;
 
 890                 ippp_table[i]->first = ippp_table[i]->rq + NUM_RCV_BUFFS - 1;
 
 891                 ippp_table[i]->last = ippp_table[i]->rq;
 
 893                 for (j = 0; j < NUM_RCV_BUFFS; j++) {
 
 894                         ippp_table[i]->rq[j].buf = NULL;
 
 895                         ippp_table[i]->rq[j].last = ippp_table[i]->rq +
 
 896                             (NUM_RCV_BUFFS + j - 1) % NUM_RCV_BUFFS;
 
 897                         ippp_table[i]->rq[j].next = ippp_table[i]->rq + (j + 1) % NUM_RCV_BUFFS;
 
 904 isdn_ppp_cleanup(void)
 
 908         for (i = 0; i < ISDN_MAX_CHANNELS; i++)
 
 909                 kfree(ippp_table[i]);
 
 911 #ifdef CONFIG_ISDN_MPP
 
 912         kfree(isdn_ppp_bundle_arr);
 
 913 #endif /* CONFIG_ISDN_MPP */
 
 918  * check for address/control field and skip if allowed
 
 919  * retval != 0 -> discard packet silently
 
 921 static int isdn_ppp_skip_ac(struct ippp_struct *is, struct sk_buff *skb) 
 
 926         if (skb->data[0] == 0xff) {
 
 930                 if (skb->data[1] != 0x03)
 
 933                 // skip address/control (AC) field
 
 936                 if (is->pppcfg & SC_REJ_COMP_AC)
 
 937                         // if AC compression was not negotiated, but used, discard packet
 
 944  * get the PPP protocol header and pull skb
 
 945  * retval < 0 -> discard packet silently
 
 947 static int isdn_ppp_strip_proto(struct sk_buff *skb) 
 
 954         if (skb->data[0] & 0x1) {
 
 955                 // protocol field is compressed
 
 956                 proto = skb->data[0];
 
 961                 proto = ((int) skb->data[0] << 8) + skb->data[1];
 
 969  * handler for incoming packets on a syncPPP interface
 
 971 void isdn_ppp_receive(isdn_net_dev * net_dev, isdn_net_local * lp, struct sk_buff *skb)
 
 973         struct ippp_struct *is;
 
 977         BUG_ON(net_dev->local->master); // we're called with the master device always
 
 980         if (slot < 0 || slot >= ISDN_MAX_CHANNELS) {
 
 981                 printk(KERN_ERR "isdn_ppp_receive: lp->ppp_slot(%d)\n",
 
 986         is = ippp_table[slot];
 
 988         if (is->debug & 0x4) {
 
 989                 printk(KERN_DEBUG "ippp_receive: is:%08lx lp:%08lx slot:%d unit:%d len:%d\n",
 
 990                        (long)is,(long)lp,lp->ppp_slot,is->unit,(int) skb->len);
 
 991                 isdn_ppp_frame_log("receive", skb->data, skb->len, 32,is->unit,lp->ppp_slot);
 
 994         if (isdn_ppp_skip_ac(is, skb) < 0) {
 
 998         proto = isdn_ppp_strip_proto(skb);
 
1004 #ifdef CONFIG_ISDN_MPP
 
1005         if (is->compflags & SC_LINK_DECOMP_ON) {
 
1006                 skb = isdn_ppp_decompress(skb, is, NULL, &proto);
 
1007                 if (!skb) // decompression error
 
1011         if (!(is->mpppcfg & SC_REJ_MP_PROT)) { // we agreed to receive MPPP
 
1012                 if (proto == PPP_MP) {
 
1013                         isdn_ppp_mp_receive(net_dev, lp, skb);
 
1018         isdn_ppp_push_higher(net_dev, lp, skb, proto);
 
1022  * we receive a reassembled frame, MPPP has been taken care of before.
 
1023  * address/control and protocol have been stripped from the skb
 
1024  * note: net_dev has to be master net_dev
 
1027 isdn_ppp_push_higher(isdn_net_dev * net_dev, isdn_net_local * lp, struct sk_buff *skb, int proto)
 
1029         struct net_device *dev = net_dev->dev;
 
1030         struct ippp_struct *is, *mis;
 
1031         isdn_net_local *mlp = NULL;
 
1034         slot = lp->ppp_slot;
 
1035         if (slot < 0 || slot >= ISDN_MAX_CHANNELS) {
 
1036                 printk(KERN_ERR "isdn_ppp_push_higher: lp->ppp_slot(%d)\n",
 
1040         is = ippp_table[slot];
 
1042         if (lp->master) { // FIXME?
 
1043                 mlp = ISDN_MASTER_PRIV(lp);
 
1044                 slot = mlp->ppp_slot;
 
1045                 if (slot < 0 || slot >= ISDN_MAX_CHANNELS) {
 
1046                         printk(KERN_ERR "isdn_ppp_push_higher: master->ppp_slot(%d)\n",
 
1051         mis = ippp_table[slot];
 
1053         if (is->debug & 0x10) {
 
1054                 printk(KERN_DEBUG "push, skb %d %04x\n", (int) skb->len, proto);
 
1055                 isdn_ppp_frame_log("rpush", skb->data, skb->len, 32,is->unit,lp->ppp_slot);
 
1057         if (mis->compflags & SC_DECOMP_ON) {
 
1058                 skb = isdn_ppp_decompress(skb, is, mis, &proto);
 
1059                 if (!skb) // decompression error
 
1063                 case PPP_IPX:  /* untested */
 
1064                         if (is->debug & 0x20)
 
1065                                 printk(KERN_DEBUG "isdn_ppp: IPX\n");
 
1066                         skb->protocol = htons(ETH_P_IPX);
 
1069                         if (is->debug & 0x20)
 
1070                                 printk(KERN_DEBUG "isdn_ppp: IP\n");
 
1071                         skb->protocol = htons(ETH_P_IP);
 
1075                         printk(KERN_INFO "isdn_ppp: unexpected compressed frame dropped\n");
 
1077 #ifdef CONFIG_ISDN_PPP_VJ
 
1078                 case PPP_VJC_UNCOMP:
 
1079                         if (is->debug & 0x20)
 
1080                                 printk(KERN_DEBUG "isdn_ppp: VJC_UNCOMP\n");
 
1081                         if (net_dev->local->ppp_slot < 0) {
 
1082                                 printk(KERN_ERR "%s: net_dev->local->ppp_slot(%d) out of range\n",
 
1083                                         __func__, net_dev->local->ppp_slot);
 
1086                         if (slhc_remember(ippp_table[net_dev->local->ppp_slot]->slcomp, skb->data, skb->len) <= 0) {
 
1087                                 printk(KERN_WARNING "isdn_ppp: received illegal VJC_UNCOMP frame!\n");
 
1090                         skb->protocol = htons(ETH_P_IP);
 
1093                         if (is->debug & 0x20)
 
1094                                 printk(KERN_DEBUG "isdn_ppp: VJC_COMP\n");
 
1096                                 struct sk_buff *skb_old = skb;
 
1098                                 skb = dev_alloc_skb(skb_old->len + 128);
 
1101                                         printk(KERN_WARNING "%s: Memory squeeze, dropping packet.\n", dev->name);
 
1105                                 skb_put(skb, skb_old->len + 128);
 
1106                                 skb_copy_from_linear_data(skb_old, skb->data,
 
1108                                 if (net_dev->local->ppp_slot < 0) {
 
1109                                         printk(KERN_ERR "%s: net_dev->local->ppp_slot(%d) out of range\n",
 
1110                                                 __func__, net_dev->local->ppp_slot);
 
1113                                 pkt_len = slhc_uncompress(ippp_table[net_dev->local->ppp_slot]->slcomp,
 
1114                                                 skb->data, skb_old->len);
 
1119                                 skb_trim(skb, pkt_len);
 
1120                                 skb->protocol = htons(ETH_P_IP);
 
1126                         isdn_ppp_receive_ccp(net_dev,lp,skb,proto);
 
1127                         /* Dont pop up ResetReq/Ack stuff to the daemon any
 
1128                            longer - the job is done already */
 
1129                         if(skb->data[0] == CCP_RESETREQ ||
 
1130                            skb->data[0] == CCP_RESETACK)
 
1134                         isdn_ppp_fill_rq(skb->data, skb->len, proto, lp->ppp_slot);     /* push data to pppd device */
 
1139 #ifdef CONFIG_IPPP_FILTER
 
1140         /* check if the packet passes the pass and active filters
 
1141          * the filter instructions are constructed assuming
 
1142          * a four-byte PPP header on each packet (which is still present) */
 
1146                 u_int16_t *p = (u_int16_t *) skb->data;
 
1148                 *p = 0; /* indicate inbound */
 
1152             && sk_run_filter(skb, is->pass_filter, is->pass_len) == 0) {
 
1153                 if (is->debug & 0x2)
 
1154                         printk(KERN_DEBUG "IPPP: inbound frame filtered.\n");
 
1158         if (!(is->active_filter
 
1159               && sk_run_filter(skb, is->active_filter,
 
1160                                is->active_len) == 0)) {
 
1161                 if (is->debug & 0x2)
 
1162                         printk(KERN_DEBUG "IPPP: link-active filter: reseting huptimer.\n");
 
1168 #else /* CONFIG_IPPP_FILTER */
 
1172 #endif /* CONFIG_IPPP_FILTER */
 
1174         skb_reset_mac_header(skb);
 
1176         /* net_dev->local->stats.rx_packets++; done in isdn_net.c */
 
1180         net_dev->local->stats.rx_dropped++;
 
1185  * isdn_ppp_skb_push ..
 
1186  * checks whether we have enough space at the beginning of the skb
 
1187  * and allocs a new SKB if necessary
 
1189 static unsigned char *isdn_ppp_skb_push(struct sk_buff **skb_p,int len)
 
1191         struct sk_buff *skb = *skb_p;
 
1193         if(skb_headroom(skb) < len) {
 
1194                 struct sk_buff *nskb = skb_realloc_headroom(skb, len);
 
1197                         printk(KERN_ERR "isdn_ppp_skb_push: can't realloc headroom!\n");
 
1201                 printk(KERN_DEBUG "isdn_ppp_skb_push:under %d %d\n",skb_headroom(skb),len);
 
1204                 return skb_push(nskb, len);
 
1206         return skb_push(skb,len);
 
1210  * send ppp frame .. we expect a PIDCOMPressable proto --
 
1211  *  (here: currently always PPP_IP,PPP_VJC_COMP,PPP_VJC_UNCOMP)
 
1213  * VJ compression may change skb pointer!!! .. requeue with old
 
1214  * skb isn't allowed!!
 
1218 isdn_ppp_xmit(struct sk_buff *skb, struct net_device *netdev)
 
1220         isdn_net_local *lp,*mlp;
 
1222         unsigned int proto = PPP_IP;     /* 0x21 */
 
1223         struct ippp_struct *ipt,*ipts;
 
1224         int slot, retval = 0;
 
1226         mlp = (isdn_net_local *) netdev_priv(netdev);
 
1227         nd = mlp->netdev;       /* get master lp */
 
1229         slot = mlp->ppp_slot;
 
1230         if (slot < 0 || slot >= ISDN_MAX_CHANNELS) {
 
1231                 printk(KERN_ERR "isdn_ppp_xmit: lp->ppp_slot(%d)\n",
 
1236         ipts = ippp_table[slot];
 
1238         if (!(ipts->pppcfg & SC_ENABLE_IP)) {   /* PPP connected ? */
 
1239                 if (ipts->debug & 0x1)
 
1240                         printk(KERN_INFO "%s: IP frame delayed.\n", netdev->name);
 
1245         switch (ntohs(skb->protocol)) {
 
1250                         proto = PPP_IPX;        /* untested */
 
1253                         printk(KERN_ERR "isdn_ppp: skipped unsupported protocol: %#x.\n", 
 
1259         lp = isdn_net_get_locked_lp(nd);
 
1261                 printk(KERN_WARNING "%s: all channels busy - requeuing!\n", netdev->name);
 
1265         /* we have our lp locked from now on */
 
1267         slot = lp->ppp_slot;
 
1268         if (slot < 0 || slot >= ISDN_MAX_CHANNELS) {
 
1269                 printk(KERN_ERR "isdn_ppp_xmit: lp->ppp_slot(%d)\n",
 
1274         ipt = ippp_table[slot];
 
1277          * after this line .. requeueing in the device queue is no longer allowed!!!
 
1280         /* Pull off the fake header we stuck on earlier to keep
 
1281          * the fragmentation code happy.
 
1283         skb_pull(skb,IPPP_MAX_HEADER);
 
1285 #ifdef CONFIG_IPPP_FILTER
 
1286         /* check if we should pass this packet
 
1287          * the filter instructions are constructed assuming
 
1288          * a four-byte PPP header on each packet */
 
1289         *skb_push(skb, 4) = 1; /* indicate outbound */
 
1292                 __be16 *p = (__be16 *)skb->data;
 
1298         if (ipt->pass_filter
 
1299             && sk_run_filter(skb, ipt->pass_filter, ipt->pass_len) == 0) {
 
1300                 if (ipt->debug & 0x4)
 
1301                         printk(KERN_DEBUG "IPPP: outbound frame filtered.\n");
 
1305         if (!(ipt->active_filter
 
1306               && sk_run_filter(skb, ipt->active_filter,
 
1307                                ipt->active_len) == 0)) {
 
1308                 if (ipt->debug & 0x4)
 
1309                         printk(KERN_DEBUG "IPPP: link-active filter: reseting huptimer.\n");
 
1313 #else /* CONFIG_IPPP_FILTER */
 
1315 #endif /* CONFIG_IPPP_FILTER */
 
1317         if (ipt->debug & 0x4)
 
1318                 printk(KERN_DEBUG "xmit skb, len %d\n", (int) skb->len);
 
1319         if (ipts->debug & 0x40)
 
1320                 isdn_ppp_frame_log("xmit0", skb->data, skb->len, 32,ipts->unit,lp->ppp_slot);
 
1322 #ifdef CONFIG_ISDN_PPP_VJ
 
1323         if (proto == PPP_IP && ipts->pppcfg & SC_COMP_TCP) {    /* ipts here? probably yes, but check this again */
 
1324                 struct sk_buff *new_skb;
 
1327                  * we need to reserve enought space in front of
 
1328                  * sk_buff. old call to dev_alloc_skb only reserved
 
1329                  * 16 bytes, now we are looking what the driver want.
 
1331                 hl = dev->drv[lp->isdn_device]->interface->hl_hdrlen + IPPP_MAX_HEADER;
 
1333                  * Note: hl might still be insufficient because the method
 
1334                  * above does not account for a possibible MPPP slave channel
 
1335                  * which had larger HL header space requirements than the
 
1338                 new_skb = alloc_skb(hl+skb->len, GFP_ATOMIC);
 
1343                         skb_reserve(new_skb, hl);
 
1344                         new_skb->dev = skb->dev;
 
1345                         skb_put(new_skb, skb->len);
 
1348                         pktlen = slhc_compress(ipts->slcomp, skb->data, skb->len, new_skb->data,
 
1349                                  &buf, !(ipts->pppcfg & SC_NO_TCP_CCID));
 
1351                         if (buf != skb->data) { 
 
1352                                 if (new_skb->data != buf)
 
1353                                         printk(KERN_ERR "isdn_ppp: FATAL error after slhc_compress!!\n");
 
1357                                 dev_kfree_skb(new_skb);
 
1360                         skb_trim(skb, pktlen);
 
1361                         if (skb->data[0] & SL_TYPE_COMPRESSED_TCP) {    /* cslip? style -> PPP */
 
1362                                 proto = PPP_VJC_COMP;
 
1363                                 skb->data[0] ^= SL_TYPE_COMPRESSED_TCP;
 
1365                                 if (skb->data[0] >= SL_TYPE_UNCOMPRESSED_TCP)
 
1366                                         proto = PPP_VJC_UNCOMP;
 
1367                                 skb->data[0] = (skb->data[0] & 0x0f) | 0x40;
 
1374          * normal (single link) or bundle compression
 
1376         if(ipts->compflags & SC_COMP_ON) {
 
1377                 /* We send compressed only if both down- und upstream
 
1378                    compression is negotiated, that means, CCP is up */
 
1379                 if(ipts->compflags & SC_DECOMP_ON) {
 
1380                         skb = isdn_ppp_compress(skb,&proto,ipt,ipts,0);
 
1382                         printk(KERN_DEBUG "isdn_ppp: CCP not yet up - sending as-is\n");
 
1386         if (ipt->debug & 0x24)
 
1387                 printk(KERN_DEBUG "xmit2 skb, len %d, proto %04x\n", (int) skb->len, proto);
 
1389 #ifdef CONFIG_ISDN_MPP
 
1390         if (ipt->mpppcfg & SC_MP_PROT) {
 
1391                 /* we get mp_seqno from static isdn_net_local */
 
1392                 long mp_seqno = ipts->mp_seqno;
 
1394                 if (ipt->mpppcfg & SC_OUT_SHORT_SEQ) {
 
1395                         unsigned char *data = isdn_ppp_skb_push(&skb, 3);
 
1399                         data[0] = MP_BEGIN_FRAG | MP_END_FRAG | ((mp_seqno >> 8) & 0xf);        /* (B)egin & (E)ndbit .. */
 
1400                         data[1] = mp_seqno & 0xff;
 
1401                         data[2] = proto;        /* PID compression */
 
1403                         unsigned char *data = isdn_ppp_skb_push(&skb, 5);
 
1406                         data[0] = MP_BEGIN_FRAG | MP_END_FRAG;  /* (B)egin & (E)ndbit .. */
 
1407                         data[1] = (mp_seqno >> 16) & 0xff;      /* sequence number: 24bit */
 
1408                         data[2] = (mp_seqno >> 8) & 0xff;
 
1409                         data[3] = (mp_seqno >> 0) & 0xff;
 
1410                         data[4] = proto;        /* PID compression */
 
1412                 proto = PPP_MP; /* MP Protocol, 0x003d */
 
1417          * 'link in bundle' compression  ...
 
1419         if(ipt->compflags & SC_LINK_COMP_ON)
 
1420                 skb = isdn_ppp_compress(skb,&proto,ipt,ipts,1);
 
1422         if( (ipt->pppcfg & SC_COMP_PROT) && (proto <= 0xff) ) {
 
1423                 unsigned char *data = isdn_ppp_skb_push(&skb,1);
 
1426                 data[0] = proto & 0xff;
 
1429                 unsigned char *data = isdn_ppp_skb_push(&skb,2);
 
1432                 data[0] = (proto >> 8) & 0xff;
 
1433                 data[1] = proto & 0xff;
 
1435         if(!(ipt->pppcfg & SC_COMP_AC)) {
 
1436                 unsigned char *data = isdn_ppp_skb_push(&skb,2);
 
1439                 data[0] = 0xff;    /* All Stations */
 
1440                 data[1] = 0x03;    /* Unnumbered information */
 
1443         /* tx-stats are now updated via BSENT-callback */
 
1445         if (ipts->debug & 0x40) {
 
1446                 printk(KERN_DEBUG "skb xmit: len: %d\n", (int) skb->len);
 
1447                 isdn_ppp_frame_log("xmit", skb->data, skb->len, 32,ipt->unit,lp->ppp_slot);
 
1450         isdn_net_writebuf_skb(lp, skb);
 
1453         spin_unlock_bh(&lp->xmit_lock);
 
1458 #ifdef CONFIG_IPPP_FILTER
 
1460  * check if this packet may trigger auto-dial.
 
1463 int isdn_ppp_autodial_filter(struct sk_buff *skb, isdn_net_local *lp)
 
1465         struct ippp_struct *is = ippp_table[lp->ppp_slot];
 
1469         switch (ntohs(skb->protocol)) {
 
1477                 printk(KERN_ERR "isdn_ppp_autodial_filter: unsupported protocol 0x%x.\n",
 
1482         /* the filter instructions are constructed assuming
 
1483          * a four-byte PPP header on each packet. we have to
 
1484          * temporarily remove part of the fake header stuck on
 
1487         *skb_pull(skb, IPPP_MAX_HEADER - 4) = 1; /* indicate outbound */
 
1490                 __be16 *p = (__be16 *)skb->data;
 
1496         drop |= is->pass_filter
 
1497                 && sk_run_filter(skb, is->pass_filter, is->pass_len) == 0;
 
1498         drop |= is->active_filter
 
1499                 && sk_run_filter(skb, is->active_filter, is->active_len) == 0;
 
1501         skb_push(skb, IPPP_MAX_HEADER - 4);
 
1505 #ifdef CONFIG_ISDN_MPP
 
1507 /* this is _not_ rfc1990 header, but something we convert both short and long
 
1508  * headers to for convinience's sake:
 
1509  *      byte 0 is flags as in rfc1990
 
1510  *      bytes 1...4 is 24-bit seqence number converted to host byte order 
 
1512 #define MP_HEADER_LEN   5
 
1514 #define MP_LONGSEQ_MASK         0x00ffffff
 
1515 #define MP_SHORTSEQ_MASK        0x00000fff
 
1516 #define MP_LONGSEQ_MAX          MP_LONGSEQ_MASK
 
1517 #define MP_SHORTSEQ_MAX         MP_SHORTSEQ_MASK
 
1518 #define MP_LONGSEQ_MAXBIT       ((MP_LONGSEQ_MASK+1)>>1)
 
1519 #define MP_SHORTSEQ_MAXBIT      ((MP_SHORTSEQ_MASK+1)>>1)
 
1521 /* sequence-wrap safe comparisions (for long sequence)*/ 
 
1522 #define MP_LT(a,b)      ((a-b)&MP_LONGSEQ_MAXBIT)
 
1523 #define MP_LE(a,b)      !((b-a)&MP_LONGSEQ_MAXBIT)
 
1524 #define MP_GT(a,b)      ((b-a)&MP_LONGSEQ_MAXBIT)
 
1525 #define MP_GE(a,b)      !((a-b)&MP_LONGSEQ_MAXBIT)
 
1527 #define MP_SEQ(f)       ((*(u32*)(f->data+1)))
 
1528 #define MP_FLAGS(f)     (f->data[0])
 
1530 static int isdn_ppp_mp_bundle_array_init(void)
 
1533         int sz = ISDN_MAX_CHANNELS*sizeof(ippp_bundle);
 
1534         if( (isdn_ppp_bundle_arr = kzalloc(sz, GFP_KERNEL)) == NULL )
 
1536         for (i = 0; i < ISDN_MAX_CHANNELS; i++) {
 
1537                 spin_lock_init(&isdn_ppp_bundle_arr[i].lock);
 
1538                 skb_queue_head_init(&isdn_ppp_bundle_arr[i].frags);
 
1543 static ippp_bundle * isdn_ppp_mp_bundle_alloc(void)
 
1546         for( i = 0; i < ISDN_MAX_CHANNELS; i++ )
 
1547                 if (isdn_ppp_bundle_arr[i].ref_ct <= 0)
 
1548                         return (isdn_ppp_bundle_arr + i);
 
1552 static int isdn_ppp_mp_init( isdn_net_local * lp, ippp_bundle * add_to )
 
1554         struct ippp_struct * is;
 
1556         if (lp->ppp_slot < 0) {
 
1557                 printk(KERN_ERR "%s: lp->ppp_slot(%d) out of range\n",
 
1558                         __func__, lp->ppp_slot);
 
1562         is = ippp_table[lp->ppp_slot];
 
1564                 if( lp->netdev->pb )
 
1565                         lp->netdev->pb->ref_ct--;
 
1566                 lp->netdev->pb = add_to;
 
1567         } else {                /* first link in a bundle */
 
1569                 if ((lp->netdev->pb = isdn_ppp_mp_bundle_alloc()) == NULL)
 
1571                 lp->next = lp->last = lp;       /* nobody else in a queue */
 
1572                 skb_queue_head_init(&lp->netdev->pb->frags);
 
1573                 lp->netdev->pb->frames = 0;
 
1574                 lp->netdev->pb->seq = UINT_MAX;
 
1576         lp->netdev->pb->ref_ct++;
 
1578         is->last_link_seqno = 0;
 
1582 static u32 isdn_ppp_mp_get_seq( int short_seq, 
 
1583                                         struct sk_buff * skb, u32 last_seq );
 
1584 static void isdn_ppp_mp_discard(ippp_bundle *mp, struct sk_buff *from,
 
1585                                 struct sk_buff *to);
 
1586 static void isdn_ppp_mp_reassembly(isdn_net_dev *net_dev, isdn_net_local *lp,
 
1587                                    struct sk_buff *from, struct sk_buff *to,
 
1589 static void isdn_ppp_mp_free_skb(ippp_bundle *mp, struct sk_buff *skb);
 
1590 static void isdn_ppp_mp_print_recv_pkt( int slot, struct sk_buff * skb );
 
1592 static void isdn_ppp_mp_receive(isdn_net_dev * net_dev, isdn_net_local * lp, 
 
1593                                 struct sk_buff *skb)
 
1595         struct sk_buff *newfrag, *frag, *start, *nextf;
 
1596         u32 newseq, minseq, thisseq;
 
1597         isdn_mppp_stats *stats;
 
1598         struct ippp_struct *is;
 
1599         unsigned long flags;
 
1600         isdn_net_local *lpq;
 
1604         spin_lock_irqsave(&net_dev->pb->lock, flags);
 
1607         slot = lp->ppp_slot;
 
1608         if (slot < 0 || slot >= ISDN_MAX_CHANNELS) {
 
1609                 printk(KERN_ERR "%s: lp->ppp_slot(%d)\n",
 
1610                         __func__, lp->ppp_slot);
 
1611                 stats->frame_drops++;
 
1613                 spin_unlock_irqrestore(&mp->lock, flags);
 
1616         is = ippp_table[slot];
 
1617         if (++mp->frames > stats->max_queue_len)
 
1618                 stats->max_queue_len = mp->frames;
 
1620         if (is->debug & 0x8)
 
1621                 isdn_ppp_mp_print_recv_pkt(lp->ppp_slot, skb);
 
1623         newseq = isdn_ppp_mp_get_seq(is->mpppcfg & SC_IN_SHORT_SEQ,
 
1624                                      skb, is->last_link_seqno);
 
1626         /* if this packet seq # is less than last already processed one,
 
1627          * toss it right away, but check for sequence start case first 
 
1629         if (mp->seq > MP_LONGSEQ_MAX && (newseq & MP_LONGSEQ_MAXBIT)) {
 
1630                 mp->seq = newseq;       /* the first packet: required for
 
1631                                          * rfc1990 non-compliant clients --
 
1632                                          * prevents constant packet toss */
 
1633         } else if( MP_LT(newseq, mp->seq) ) {
 
1634                 stats->frame_drops++;
 
1635                 isdn_ppp_mp_free_skb(mp, skb);
 
1636                 spin_unlock_irqrestore(&mp->lock, flags);
 
1640         /* find the minimum received sequence number over all links */
 
1641         is->last_link_seqno = minseq = newseq;
 
1642         for (lpq = net_dev->queue;;) {
 
1643                 slot = lpq->ppp_slot;
 
1644                 if (slot < 0 || slot >= ISDN_MAX_CHANNELS) {
 
1645                         printk(KERN_ERR "%s: lpq->ppp_slot(%d)\n",
 
1646                                 __func__, lpq->ppp_slot);
 
1648                         u32 lls = ippp_table[slot]->last_link_seqno;
 
1649                         if (MP_LT(lls, minseq))
 
1652                 if ((lpq = lpq->next) == net_dev->queue)
 
1655         if (MP_LT(minseq, mp->seq))
 
1656                 minseq = mp->seq;       /* can't go beyond already processed
 
1660         /* Insert new fragment into the proper sequence slot.  */
 
1661         skb_queue_walk(&mp->frags, frag) {
 
1662                 if (MP_SEQ(frag) == newseq) {
 
1663                         isdn_ppp_mp_free_skb(mp, newfrag);
 
1667                 if (MP_LT(newseq, MP_SEQ(frag))) {
 
1668                         __skb_queue_before(&mp->frags, frag, newfrag);
 
1674                 __skb_queue_tail(&mp->frags, newfrag);
 
1676         frag = skb_peek(&mp->frags);
 
1677         start = ((MP_FLAGS(frag) & MP_BEGIN_FRAG) &&
 
1678                  (MP_SEQ(frag) == mp->seq)) ? frag : NULL;
 
1680                 goto check_overflow;
 
1682         /* main fragment traversing loop
 
1684          * try to accomplish several tasks:
 
1685          * - reassemble any complete fragment sequence (non-null 'start'
 
1686          *   indicates there is a continguous sequence present)
 
1687          * - discard any incomplete sequences that are below minseq -- due
 
1688          *   to the fact that sender always increment sequence number, if there
 
1689          *   is an incomplete sequence below minseq, no new fragments would
 
1690          *   come to complete such sequence and it should be discarded
 
1692          * loop completes when we accomplished the following tasks:
 
1693          * - we hit a gap in the sequence, so no reassembly/processing is 
 
1694          *   possible ('start' would be set to NULL)
 
1696          * algorithm for this code is derived from code in the book
 
1697          * 'PPP Design And Debugging' by James Carlson (Addison-Wesley)
 
1699         skb_queue_walk_safe(&mp->frags, frag, nextf) {
 
1700                 thisseq = MP_SEQ(frag);
 
1702                 /* check for misplaced start */
 
1703                 if (start != frag && (MP_FLAGS(frag) & MP_BEGIN_FRAG)) {
 
1704                         printk(KERN_WARNING"isdn_mppp(seq %d): new "
 
1705                                "BEGIN flag with no prior END", thisseq);
 
1707                         stats->frame_drops++;
 
1708                         isdn_ppp_mp_discard(mp, start, frag);
 
1710                 } else if (MP_LE(thisseq, minseq)) {            
 
1711                         if (MP_FLAGS(frag) & MP_BEGIN_FRAG)
 
1714                                 if (MP_FLAGS(frag) & MP_END_FRAG)
 
1715                                         stats->frame_drops++;
 
1716                                 __skb_unlink(skb, &mp->frags);
 
1717                                 isdn_ppp_mp_free_skb(mp, frag);
 
1722                 /* if we have end fragment, then we have full reassembly
 
1723                  * sequence -- reassemble and process packet now
 
1725                 if (MP_FLAGS(frag) & MP_END_FRAG) {
 
1726                         minseq = mp->seq = (thisseq+1) & MP_LONGSEQ_MASK;
 
1727                         /* Reassemble the packet then dispatch it */
 
1728                         isdn_ppp_mp_reassembly(net_dev, lp, start, frag, thisseq);
 
1734                 /* check if need to update start pointer: if we just
 
1735                  * reassembled the packet and sequence is contiguous
 
1736                  * then next fragment should be the start of new reassembly
 
1737                  * if sequence is contiguous, but we haven't reassembled yet,
 
1739                  * if sequence is not contiguous, either clear everyting
 
1740                  * below low watermark and set start to the next frag or
 
1743                 if (nextf != (struct sk_buff *)&mp->frags && 
 
1744                     ((thisseq+1) & MP_LONGSEQ_MASK) == MP_SEQ(nextf)) {
 
1745                         /* if we just reassembled and the next one is here, 
 
1746                          * then start another reassembly.
 
1749                                 if (MP_FLAGS(nextf) & MP_BEGIN_FRAG)
 
1752                                         printk(KERN_WARNING"isdn_mppp(seq %d):"
 
1753                                                " END flag with no following "
 
1759                         if (nextf != (struct sk_buff *)&mp->frags &&
 
1761                             MP_LT(thisseq, minseq)) {
 
1762                                 /* we've got a break in the sequence
 
1763                                  * and we not at the end yet
 
1764                                  * and we did not just reassembled
 
1765                                  *(if we did, there wouldn't be anything before)
 
1766                                  * and we below the low watermark 
 
1767                                  * discard all the frames below low watermark 
 
1769                                 stats->frame_drops++;
 
1770                                 isdn_ppp_mp_discard(mp, start, nextf);
 
1772                         /* break in the sequence, no reassembly */
 
1780         /* rather straighforward way to deal with (not very) possible 
 
1783         if (mp->frames > MP_MAX_QUEUE_LEN) {
 
1785                 skb_queue_walk_safe(&mp->frags, frag, nextf) {
 
1786                         if (mp->frames <= MP_MAX_QUEUE_LEN)
 
1788                         __skb_unlink(frag, &mp->frags);
 
1789                         isdn_ppp_mp_free_skb(mp, frag);
 
1792         spin_unlock_irqrestore(&mp->lock, flags);
 
1795 static void isdn_ppp_mp_cleanup(isdn_net_local *lp)
 
1797         struct sk_buff *skb, *tmp;
 
1799         skb_queue_walk_safe(&lp->netdev->pb->frags, skb, tmp) {
 
1800                 __skb_unlink(skb, &lp->netdev->pb->frags);
 
1801                 isdn_ppp_mp_free_skb(lp->netdev->pb, skb);
 
1805 static u32 isdn_ppp_mp_get_seq( int short_seq, 
 
1806                                         struct sk_buff * skb, u32 last_seq )
 
1809         int flags = skb->data[0] & (MP_BEGIN_FRAG | MP_END_FRAG);
 
1813                 seq = ntohl(*(__be32 *)skb->data) & MP_LONGSEQ_MASK;
 
1818                 /* convert 12-bit short seq number to 24-bit long one 
 
1820                 seq = ntohs(*(__be16 *)skb->data) & MP_SHORTSEQ_MASK;
 
1822                 /* check for seqence wrap */
 
1823                 if( !(seq &  MP_SHORTSEQ_MAXBIT) && 
 
1824                      (last_seq &  MP_SHORTSEQ_MAXBIT) && 
 
1825                      (unsigned long)last_seq <= MP_LONGSEQ_MAX )
 
1826                         seq |= (last_seq + MP_SHORTSEQ_MAX+1) & 
 
1827                                         (~MP_SHORTSEQ_MASK & MP_LONGSEQ_MASK);
 
1829                         seq |= last_seq & (~MP_SHORTSEQ_MASK & MP_LONGSEQ_MASK);
 
1831                 skb_push(skb, 3);       /* put converted seqence back in skb */
 
1833         *(u32*)(skb->data+1) = seq;     /* put seqence back in _host_ byte
 
1835         skb->data[0] = flags;           /* restore flags */
 
1839 static void isdn_ppp_mp_discard(ippp_bundle *mp, struct sk_buff *from,
 
1843                 struct sk_buff *skb, *tmp;
 
1846                 skb_queue_walk_safe(&mp->frags, skb, tmp) {
 
1853                         __skb_unlink(skb, &mp->frags);
 
1854                         isdn_ppp_mp_free_skb(mp, skb);
 
1859 static unsigned int calc_tot_len(struct sk_buff_head *queue,
 
1860                                  struct sk_buff *from, struct sk_buff *to)
 
1862         unsigned int tot_len = 0;
 
1863         struct sk_buff *skb;
 
1864         int found_start = 0;
 
1866         skb_queue_walk(queue, skb) {
 
1871                 tot_len += skb->len - MP_HEADER_LEN;
 
1878 /* Reassemble packet using fragments in the reassembly queue from
 
1879  * 'from' until 'to', inclusive.
 
1881 static void isdn_ppp_mp_reassembly(isdn_net_dev *net_dev, isdn_net_local *lp,
 
1882                                    struct sk_buff *from, struct sk_buff *to,
 
1885         ippp_bundle *mp = net_dev->pb;
 
1886         unsigned int tot_len;
 
1887         struct sk_buff *skb;
 
1890         if (lp->ppp_slot < 0 || lp->ppp_slot >= ISDN_MAX_CHANNELS) {
 
1891                 printk(KERN_ERR "%s: lp->ppp_slot(%d) out of range\n",
 
1892                         __func__, lp->ppp_slot);
 
1896         tot_len = calc_tot_len(&mp->frags, from, to);
 
1898         if (MP_FLAGS(from) == (MP_BEGIN_FRAG | MP_END_FRAG)) {
 
1899                 if (ippp_table[lp->ppp_slot]->debug & 0x40)
 
1900                         printk(KERN_DEBUG "isdn_mppp: reassembly: frame %d, "
 
1901                                "len %d\n", MP_SEQ(from), from->len);
 
1903                 skb_pull(skb, MP_HEADER_LEN);
 
1904                 __skb_unlink(skb, &mp->frags);
 
1907                 struct sk_buff *walk, *tmp;
 
1908                 int found_start = 0;
 
1910                 if (ippp_table[lp->ppp_slot]->debug & 0x40)
 
1911                         printk(KERN_DEBUG"isdn_mppp: reassembling frames %d "
 
1912                                "to %d, len %d\n", MP_SEQ(from), lastseq,
 
1915                 skb = dev_alloc_skb(tot_len);
 
1917                         printk(KERN_ERR "isdn_mppp: cannot allocate sk buff "
 
1918                                "of size %d\n", tot_len);
 
1921                 skb_queue_walk_safe(&mp->frags, walk, tmp) {
 
1928                                 unsigned int len = walk->len - MP_HEADER_LEN;
 
1929                                 skb_copy_from_linear_data_offset(walk, MP_HEADER_LEN,
 
1933                         __skb_unlink(walk, &mp->frags);
 
1934                         isdn_ppp_mp_free_skb(mp, walk);
 
1943         proto = isdn_ppp_strip_proto(skb);
 
1944         isdn_ppp_push_higher(net_dev, lp, skb, proto);
 
1947 static void isdn_ppp_mp_free_skb(ippp_bundle *mp, struct sk_buff *skb)
 
1953 static void isdn_ppp_mp_print_recv_pkt( int slot, struct sk_buff * skb )
 
1955         printk(KERN_DEBUG "mp_recv: %d/%d -> %02x %02x %02x %02x %02x %02x\n", 
 
1956                 slot, (int) skb->len, 
 
1957                 (int) skb->data[0], (int) skb->data[1], (int) skb->data[2],
 
1958                 (int) skb->data[3], (int) skb->data[4], (int) skb->data[5]);
 
1962 isdn_ppp_bundle(struct ippp_struct *is, int unit)
 
1964         char ifn[IFNAMSIZ + 1];
 
1966         isdn_net_local *lp, *nlp;
 
1968         unsigned long flags;
 
1970         sprintf(ifn, "ippp%d", unit);
 
1971         p = isdn_net_findif(ifn);
 
1973                 printk(KERN_ERR "ippp_bundle: cannot find %s\n", ifn);
 
1977         spin_lock_irqsave(&p->pb->lock, flags);
 
1981         if( nlp->ppp_slot < 0 || nlp->ppp_slot >= ISDN_MAX_CHANNELS ||
 
1982                 lp->ppp_slot < 0 || lp->ppp_slot >= ISDN_MAX_CHANNELS ) {
 
1983                 printk(KERN_ERR "ippp_bundle: binding to invalid slot %d\n",
 
1984                         nlp->ppp_slot < 0 || nlp->ppp_slot >= ISDN_MAX_CHANNELS ? 
 
1985                         nlp->ppp_slot : lp->ppp_slot );
 
1990         isdn_net_add_to_bundle(p, nlp);
 
1992         ippp_table[nlp->ppp_slot]->unit = ippp_table[lp->ppp_slot]->unit;
 
1994         /* maybe also SC_CCP stuff */
 
1995         ippp_table[nlp->ppp_slot]->pppcfg |= ippp_table[lp->ppp_slot]->pppcfg &
 
1996                 (SC_ENABLE_IP | SC_NO_TCP_CCID | SC_REJ_COMP_TCP);
 
1997         ippp_table[nlp->ppp_slot]->mpppcfg |= ippp_table[lp->ppp_slot]->mpppcfg &
 
1998                 (SC_MP_PROT | SC_REJ_MP_PROT | SC_OUT_SHORT_SEQ | SC_IN_SHORT_SEQ);
 
1999         rc = isdn_ppp_mp_init(nlp, p->pb);
 
2001         spin_unlock_irqrestore(&p->pb->lock, flags);
 
2005 #endif /* CONFIG_ISDN_MPP */
 
2008  * network device ioctl handlers
 
2012 isdn_ppp_dev_ioctl_stats(int slot, struct ifreq *ifr, struct net_device *dev)
 
2014         struct ppp_stats __user *res = ifr->ifr_data;
 
2016         isdn_net_local *lp = (isdn_net_local *) netdev_priv(dev);
 
2018         if (!access_ok(VERIFY_WRITE, res, sizeof(struct ppp_stats)))
 
2021         /* build a temporary stat struct and copy it to user space */
 
2023         memset(&t, 0, sizeof(struct ppp_stats));
 
2024         if (dev->flags & IFF_UP) {
 
2025                 t.p.ppp_ipackets = lp->stats.rx_packets;
 
2026                 t.p.ppp_ibytes = lp->stats.rx_bytes;
 
2027                 t.p.ppp_ierrors = lp->stats.rx_errors;
 
2028                 t.p.ppp_opackets = lp->stats.tx_packets;
 
2029                 t.p.ppp_obytes = lp->stats.tx_bytes;
 
2030                 t.p.ppp_oerrors = lp->stats.tx_errors;
 
2031 #ifdef CONFIG_ISDN_PPP_VJ
 
2032                 if (slot >= 0 && ippp_table[slot]->slcomp) {
 
2033                         struct slcompress *slcomp = ippp_table[slot]->slcomp;
 
2034                         t.vj.vjs_packets = slcomp->sls_o_compressed + slcomp->sls_o_uncompressed;
 
2035                         t.vj.vjs_compressed = slcomp->sls_o_compressed;
 
2036                         t.vj.vjs_searches = slcomp->sls_o_searches;
 
2037                         t.vj.vjs_misses = slcomp->sls_o_misses;
 
2038                         t.vj.vjs_errorin = slcomp->sls_i_error;
 
2039                         t.vj.vjs_tossed = slcomp->sls_i_tossed;
 
2040                         t.vj.vjs_uncompressedin = slcomp->sls_i_uncompressed;
 
2041                         t.vj.vjs_compressedin = slcomp->sls_i_compressed;
 
2045         if (copy_to_user(res, &t, sizeof(struct ppp_stats)))
 
2051 isdn_ppp_dev_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
 
2055         isdn_net_local *lp = (isdn_net_local *) netdev_priv(dev);
 
2058         if (lp->p_encap != ISDN_NET_ENCAP_SYNCPPP)
 
2062 #define PPP_VERSION "2.3.7"
 
2064                         len = strlen(PPP_VERSION) + 1;
 
2065                         if (copy_to_user(ifr->ifr_data, PPP_VERSION, len))
 
2070                         error = isdn_ppp_dev_ioctl_stats(lp->ppp_slot, ifr, dev);
 
2080 isdn_ppp_if_get_unit(char *name)
 
2089         if (strncmp("ippp", name, 4) || len > 8)
 
2092         for (i = 0, deci = 1; i < len; i++, deci *= 10) {
 
2093                 char a = name[len - i - 1];
 
2094                 if (a >= '0' && a <= '9')
 
2095                         unit += (a - '0') * deci;
 
2099         if (!i || len - i != 4)
 
2107 isdn_ppp_dial_slave(char *name)
 
2109 #ifdef CONFIG_ISDN_MPP
 
2112         struct net_device *sdev;
 
2114         if (!(ndev = isdn_net_findif(name)))
 
2117         if (!(lp->flags & ISDN_NET_CONNECTED))
 
2122                 isdn_net_local *mlp = (isdn_net_local *) netdev_priv(sdev);
 
2123                 if (!(mlp->flags & ISDN_NET_CONNECTED))
 
2130         isdn_net_dial_req((isdn_net_local *) netdev_priv(sdev));
 
2138 isdn_ppp_hangup_slave(char *name)
 
2140 #ifdef CONFIG_ISDN_MPP
 
2143         struct net_device *sdev;
 
2145         if (!(ndev = isdn_net_findif(name)))
 
2148         if (!(lp->flags & ISDN_NET_CONNECTED))
 
2153                 isdn_net_local *mlp = (isdn_net_local *) netdev_priv(sdev);
 
2155                 if (mlp->slave) { /* find last connected link in chain */
 
2156                         isdn_net_local *nlp = ISDN_SLAVE_PRIV(mlp);
 
2158                         if (!(nlp->flags & ISDN_NET_CONNECTED))
 
2160                 } else if (mlp->flags & ISDN_NET_CONNECTED)
 
2168         isdn_net_hangup(sdev);
 
2176  * PPP compression stuff
 
2180 /* Push an empty CCP Data Frame up to the daemon to wake it up and let it
 
2181    generate a CCP Reset-Request or tear down CCP altogether */
 
2183 static void isdn_ppp_ccp_kickup(struct ippp_struct *is)
 
2185         isdn_ppp_fill_rq(NULL, 0, PPP_COMP, is->lp->ppp_slot);
 
2188 /* In-kernel handling of CCP Reset-Request and Reset-Ack is necessary,
 
2189    but absolutely nontrivial. The most abstruse problem we are facing is
 
2190    that the generation, reception and all the handling of timeouts and
 
2191    resends including proper request id management should be entirely left
 
2192    to the (de)compressor, but indeed is not covered by the current API to
 
2193    the (de)compressor. The API is a prototype version from PPP where only
 
2194    some (de)compressors have yet been implemented and all of them are
 
2195    rather simple in their reset handling. Especially, their is only one
 
2196    outstanding ResetAck at a time with all of them and ResetReq/-Acks do
 
2197    not have parameters. For this very special case it was sufficient to
 
2198    just return an error code from the decompressor and have a single
 
2199    reset() entry to communicate all the necessary information between
 
2200    the framework and the (de)compressor. Bad enough, LZS is different
 
2201    (and any other compressor may be different, too). It has multiple
 
2202    histories (eventually) and needs to Reset each of them independently
 
2203    and thus uses multiple outstanding Acks and history numbers as an
 
2204    additional parameter to Reqs/Acks.
 
2205    All that makes it harder to port the reset state engine into the
 
2206    kernel because it is not just the same simple one as in (i)pppd but
 
2207    it must be able to pass additional parameters and have multiple out-
 
2208    standing Acks. We are trying to achieve the impossible by handling
 
2209    reset transactions independent by their id. The id MUST change when
 
2210    the data portion changes, thus any (de)compressor who uses more than
 
2211    one resettable state must provide and recognize individual ids for
 
2212    each individual reset transaction. The framework itself does _only_
 
2213    differentiate them by id, because it has no other semantics like the
 
2214    (de)compressor might.
 
2215    This looks like a major redesign of the interface would be nice,
 
2216    but I don't have an idea how to do it better. */
 
2218 /* Send a CCP Reset-Request or Reset-Ack directly from the kernel. This is
 
2219    getting that lengthy because there is no simple "send-this-frame-out"
 
2220    function above but every wrapper does a bit different. Hope I guess
 
2221    correct in this hack... */
 
2223 static void isdn_ppp_ccp_xmit_reset(struct ippp_struct *is, int proto,
 
2224                                     unsigned char code, unsigned char id,
 
2225                                     unsigned char *data, int len)
 
2227         struct sk_buff *skb;
 
2231         isdn_net_local *lp = is->lp;
 
2233         /* Alloc large enough skb */
 
2234         hl = dev->drv[lp->isdn_device]->interface->hl_hdrlen;
 
2235         skb = alloc_skb(len + hl + 16,GFP_ATOMIC);
 
2238                        "ippp: CCP cannot send reset - out of memory\n");
 
2241         skb_reserve(skb, hl);
 
2243         /* We may need to stuff an address and control field first */
 
2244         if(!(is->pppcfg & SC_COMP_AC)) {
 
2245                 p = skb_put(skb, 2);
 
2250         /* Stuff proto, code, id and length */
 
2251         p = skb_put(skb, 6);
 
2252         *p++ = (proto >> 8);
 
2253         *p++ = (proto & 0xff);
 
2258         *p++ = (cnt & 0xff);
 
2260         /* Now stuff remaining bytes */
 
2262                 p = skb_put(skb, len);
 
2263                 memcpy(p, data, len);
 
2266         /* skb is now ready for xmit */
 
2267         printk(KERN_DEBUG "Sending CCP Frame:\n");
 
2268         isdn_ppp_frame_log("ccp-xmit", skb->data, skb->len, 32, is->unit,lp->ppp_slot);
 
2270         isdn_net_write_super(lp, skb);
 
2273 /* Allocate the reset state vector */
 
2274 static struct ippp_ccp_reset *isdn_ppp_ccp_reset_alloc(struct ippp_struct *is)
 
2276         struct ippp_ccp_reset *r;
 
2277         r = kzalloc(sizeof(struct ippp_ccp_reset), GFP_KERNEL);
 
2279                 printk(KERN_ERR "ippp_ccp: failed to allocate reset data"
 
2280                        " structure - no mem\n");
 
2283         printk(KERN_DEBUG "ippp_ccp: allocated reset data structure %p\n", r);
 
2288 /* Destroy the reset state vector. Kill all pending timers first. */
 
2289 static void isdn_ppp_ccp_reset_free(struct ippp_struct *is)
 
2293         printk(KERN_DEBUG "ippp_ccp: freeing reset data structure %p\n",
 
2295         for(id = 0; id < 256; id++) {
 
2296                 if(is->reset->rs[id]) {
 
2297                         isdn_ppp_ccp_reset_free_state(is, (unsigned char)id);
 
2304 /* Free a given state and clear everything up for later reallocation */
 
2305 static void isdn_ppp_ccp_reset_free_state(struct ippp_struct *is,
 
2308         struct ippp_ccp_reset_state *rs;
 
2310         if(is->reset->rs[id]) {
 
2311                 printk(KERN_DEBUG "ippp_ccp: freeing state for id %d\n", id);
 
2312                 rs = is->reset->rs[id];
 
2313                 /* Make sure the kernel will not call back later */
 
2315                         del_timer(&rs->timer);
 
2316                 is->reset->rs[id] = NULL;
 
2319                 printk(KERN_WARNING "ippp_ccp: id %d is not allocated\n", id);
 
2323 /* The timer callback function which is called when a ResetReq has timed out,
 
2324    aka has never been answered by a ResetAck */
 
2325 static void isdn_ppp_ccp_timer_callback(unsigned long closure)
 
2327         struct ippp_ccp_reset_state *rs =
 
2328                 (struct ippp_ccp_reset_state *)closure;
 
2331                 printk(KERN_ERR "ippp_ccp: timer cb with zero closure.\n");
 
2334         if(rs->ta && rs->state == CCPResetSentReq) {
 
2335                 /* We are correct here */
 
2337                         /* Hmm, there is no Ack really expected. We can clean
 
2338                            up the state now, it will be reallocated if the
 
2339                            decompressor insists on another reset */
 
2341                         isdn_ppp_ccp_reset_free_state(rs->is, rs->id);
 
2344                 printk(KERN_DEBUG "ippp_ccp: CCP Reset timed out for id %d\n",
 
2347                 isdn_ppp_ccp_xmit_reset(rs->is, PPP_CCP, CCP_RESETREQ, rs->id,
 
2348                                         rs->data, rs->dlen);
 
2350                 rs->timer.expires = jiffies + HZ*5;
 
2351                 add_timer(&rs->timer);
 
2353                 printk(KERN_WARNING "ippp_ccp: timer cb in wrong state %d\n",
 
2358 /* Allocate a new reset transaction state */
 
2359 static struct ippp_ccp_reset_state *isdn_ppp_ccp_reset_alloc_state(struct ippp_struct *is,
 
2362         struct ippp_ccp_reset_state *rs;
 
2363         if(is->reset->rs[id]) {
 
2364                 printk(KERN_WARNING "ippp_ccp: old state exists for id %d\n",
 
2368                 rs = kzalloc(sizeof(struct ippp_ccp_reset_state), GFP_KERNEL);
 
2371                 rs->state = CCPResetIdle;
 
2374                 init_timer(&rs->timer);
 
2375                 rs->timer.data = (unsigned long)rs;
 
2376                 rs->timer.function = isdn_ppp_ccp_timer_callback;
 
2377                 is->reset->rs[id] = rs;
 
2383 /* A decompressor wants a reset with a set of parameters - do what is
 
2384    necessary to fulfill it */
 
2385 static void isdn_ppp_ccp_reset_trans(struct ippp_struct *is,
 
2386                                      struct isdn_ppp_resetparams *rp)
 
2388         struct ippp_ccp_reset_state *rs;
 
2391                 /* The decompressor defines parameters by itself */
 
2393                         /* And he wants us to send a request */
 
2395                                 printk(KERN_ERR "ippp_ccp: decompressor must"
 
2396                                        " specify reset id\n");
 
2399                         if(is->reset->rs[rp->id]) {
 
2400                                 /* There is already a transaction in existence
 
2401                                    for this id. May be still waiting for a
 
2402                                    Ack or may be wrong. */
 
2403                                 rs = is->reset->rs[rp->id];
 
2404                                 if(rs->state == CCPResetSentReq && rs->ta) {
 
2405                                         printk(KERN_DEBUG "ippp_ccp: reset"
 
2406                                                " trans still in progress"
 
2407                                                " for id %d\n", rp->id);
 
2409                                         printk(KERN_WARNING "ippp_ccp: reset"
 
2410                                                " trans in wrong state %d for"
 
2411                                                " id %d\n", rs->state, rp->id);
 
2414                                 /* Ok, this is a new transaction */
 
2415                                 printk(KERN_DEBUG "ippp_ccp: new trans for id"
 
2416                                        " %d to be started\n", rp->id);
 
2417                                 rs = isdn_ppp_ccp_reset_alloc_state(is, rp->id);
 
2419                                         printk(KERN_ERR "ippp_ccp: out of mem"
 
2420                                                " allocing ccp trans\n");
 
2423                                 rs->state = CCPResetSentReq;
 
2424                                 rs->expra = rp->expra;
 
2426                                         rs->dlen = rp->dlen;
 
2427                                         memcpy(rs->data, rp->data, rp->dlen);
 
2429                                 /* HACK TODO - add link comp here */
 
2430                                 isdn_ppp_ccp_xmit_reset(is, PPP_CCP,
 
2431                                                         CCP_RESETREQ, rs->id,
 
2432                                                         rs->data, rs->dlen);
 
2433                                 /* Start the timer */
 
2434                                 rs->timer.expires = jiffies + 5*HZ;
 
2435                                 add_timer(&rs->timer);
 
2439                         printk(KERN_DEBUG "ippp_ccp: no reset sent\n");
 
2442                 /* The reset params are invalid. The decompressor does not
 
2443                    care about them, so we just send the minimal requests
 
2444                    and increase ids only when an Ack is received for a
 
2446                 if(is->reset->rs[is->reset->lastid]) {
 
2447                         /* There is already a transaction in existence
 
2448                            for this id. May be still waiting for a
 
2449                            Ack or may be wrong. */
 
2450                         rs = is->reset->rs[is->reset->lastid];
 
2451                         if(rs->state == CCPResetSentReq && rs->ta) {
 
2452                                 printk(KERN_DEBUG "ippp_ccp: reset"
 
2453                                        " trans still in progress"
 
2454                                        " for id %d\n", rp->id);
 
2456                                 printk(KERN_WARNING "ippp_ccp: reset"
 
2457                                        " trans in wrong state %d for"
 
2458                                        " id %d\n", rs->state, rp->id);
 
2461                         printk(KERN_DEBUG "ippp_ccp: new trans for id"
 
2462                                " %d to be started\n", is->reset->lastid);
 
2463                         rs = isdn_ppp_ccp_reset_alloc_state(is,
 
2466                                 printk(KERN_ERR "ippp_ccp: out of mem"
 
2467                                        " allocing ccp trans\n");
 
2470                         rs->state = CCPResetSentReq;
 
2471                         /* We always expect an Ack if the decompressor doesn't
 
2475                         /* HACK TODO - add link comp here */
 
2476                         isdn_ppp_ccp_xmit_reset(is, PPP_CCP, CCP_RESETREQ,
 
2478                         /* Start the timer */
 
2479                         rs->timer.expires = jiffies + 5*HZ;
 
2480                         add_timer(&rs->timer);
 
2486 /* An Ack was received for this id. This means we stop the timer and clean
 
2487    up the state prior to calling the decompressors reset routine. */
 
2488 static void isdn_ppp_ccp_reset_ack_rcvd(struct ippp_struct *is,
 
2491         struct ippp_ccp_reset_state *rs = is->reset->rs[id];
 
2494                 if(rs->ta && rs->state == CCPResetSentReq) {
 
2495                         /* Great, we are correct */
 
2497                                 printk(KERN_DEBUG "ippp_ccp: ResetAck received"
 
2498                                        " for id %d but not expected\n", id);
 
2500                         printk(KERN_INFO "ippp_ccp: ResetAck received out of"
 
2501                                "sync for id %d\n", id);
 
2505                         del_timer(&rs->timer);
 
2507                 isdn_ppp_ccp_reset_free_state(is, id);
 
2509                 printk(KERN_INFO "ippp_ccp: ResetAck received for unknown id"
 
2512         /* Make sure the simple reset stuff uses a new id next time */
 
2513         is->reset->lastid++;
 
2519  * if master = 0, we're trying to uncompress an per-link compressed packet,
 
2520  * as opposed to an compressed reconstructed-from-MPPP packet.
 
2521  * proto is updated to protocol field of uncompressed packet.
 
2523  * retval: decompressed packet,
 
2524  *         same packet if uncompressed,
 
2525  *         NULL if decompression error
 
2528 static struct sk_buff *isdn_ppp_decompress(struct sk_buff *skb,struct ippp_struct *is,struct ippp_struct *master,
 
2532         struct isdn_ppp_compressor *ipc = NULL;
 
2533         struct sk_buff *skb_out;
 
2535         struct ippp_struct *ri;
 
2536         struct isdn_ppp_resetparams rsparm;
 
2537         unsigned char rsdata[IPPP_RESET_MAXDATABYTES];
 
2540                 // per-link decompression 
 
2541                 stat = is->link_decomp_stat;
 
2542                 ipc = is->link_decompressor;
 
2545                 stat = master->decomp_stat;
 
2546                 ipc = master->decompressor;
 
2551                 // no decompressor -> we can't decompress.
 
2552                 printk(KERN_DEBUG "ippp: no decompressor defined!\n");
 
2555         BUG_ON(!stat); // if we have a compressor, stat has been set as well
 
2557         if((master && *proto == PPP_COMP) || (!master && *proto == PPP_COMPFRAG) ) {
 
2558                 // compressed packets are compressed by their protocol type
 
2560                 // Set up reset params for the decompressor
 
2561                 memset(&rsparm, 0, sizeof(rsparm));
 
2562                 rsparm.data = rsdata;
 
2563                 rsparm.maxdlen = IPPP_RESET_MAXDATABYTES;
 
2565                 skb_out = dev_alloc_skb(is->mru + PPP_HDRLEN);
 
2568                         printk(KERN_ERR "ippp: decomp memory allocation failure\n");
 
2571                 len = ipc->decompress(stat, skb, skb_out, &rsparm);
 
2576                                 printk(KERN_INFO "ippp: decomp wants reset %s params\n",
 
2577                                        rsparm.valid ? "with" : "without");
 
2579                                 isdn_ppp_ccp_reset_trans(ri, &rsparm);
 
2581                         case DECOMP_FATALERROR:
 
2582                                 ri->pppcfg |= SC_DC_FERROR;
 
2583                                 /* Kick ipppd to recognize the error */
 
2584                                 isdn_ppp_ccp_kickup(ri);
 
2590                 *proto = isdn_ppp_strip_proto(skb_out);
 
2597                 // uncompressed packets are fed through the decompressor to
 
2598                 // update the decompressor state
 
2599                 ipc->incomp(stat, skb, *proto);
 
2606  *   type=0: normal/bundle compression
 
2607  *       =1: link compression
 
2608  * returns original skb if we haven't compressed the frame
 
2609  * and a new skb pointer if we've done it
 
2611 static struct sk_buff *isdn_ppp_compress(struct sk_buff *skb_in,int *proto,
 
2612         struct ippp_struct *is,struct ippp_struct *master,int type)
 
2616     struct isdn_ppp_compressor *compressor;
 
2618     struct sk_buff *skb_out;
 
2620         /* we do not compress control protocols */
 
2621     if(*proto < 0 || *proto > 0x3fff) {
 
2625         if(type) { /* type=1 => Link compression */
 
2630                         compressor = is->compressor;
 
2631                         stat = is->comp_stat;
 
2634                         compressor = master->compressor;
 
2635                         stat = master->comp_stat;
 
2637                 new_proto = PPP_COMP;
 
2641                 printk(KERN_ERR "isdn_ppp: No compressor set!\n");
 
2645                 printk(KERN_ERR "isdn_ppp: Compressor not initialized?\n");
 
2649         /* Allow for at least 150 % expansion (for now) */
 
2650         skb_out = alloc_skb(skb_in->len + skb_in->len/2 + 32 +
 
2651                 skb_headroom(skb_in), GFP_ATOMIC);
 
2654         skb_reserve(skb_out, skb_headroom(skb_in));
 
2656         ret = (compressor->compress)(stat,skb_in,skb_out,*proto);
 
2658                 dev_kfree_skb(skb_out);
 
2662         dev_kfree_skb(skb_in);
 
2668  * we received a CCP frame .. 
 
2669  * not a clean solution, but we MUST handle a few cases in the kernel
 
2671 static void isdn_ppp_receive_ccp(isdn_net_dev *net_dev, isdn_net_local *lp,
 
2672          struct sk_buff *skb,int proto)
 
2674         struct ippp_struct *is;
 
2675         struct ippp_struct *mis;
 
2677         struct isdn_ppp_resetparams rsparm;
 
2678         unsigned char rsdata[IPPP_RESET_MAXDATABYTES];  
 
2680         printk(KERN_DEBUG "Received CCP frame from peer slot(%d)\n",
 
2682         if (lp->ppp_slot < 0 || lp->ppp_slot >= ISDN_MAX_CHANNELS) {
 
2683                 printk(KERN_ERR "%s: lp->ppp_slot(%d) out of range\n",
 
2684                         __func__, lp->ppp_slot);
 
2687         is = ippp_table[lp->ppp_slot];
 
2688         isdn_ppp_frame_log("ccp-rcv", skb->data, skb->len, 32, is->unit,lp->ppp_slot);
 
2691                 int slot = ISDN_MASTER_PRIV(lp)->ppp_slot;
 
2692                 if (slot < 0 || slot >= ISDN_MAX_CHANNELS) {
 
2693                         printk(KERN_ERR "%s: slot(%d) out of range\n",
 
2697                 mis = ippp_table[slot];
 
2701         switch(skb->data[0]) {
 
2703                 if(is->debug & 0x10)
 
2704                         printk(KERN_DEBUG "Disable compression here!\n");
 
2705                 if(proto == PPP_CCP)
 
2706                         mis->compflags &= ~SC_COMP_ON;          
 
2708                         is->compflags &= ~SC_LINK_COMP_ON;              
 
2712                 if(is->debug & 0x10)
 
2713                         printk(KERN_DEBUG "Disable (de)compression here!\n");
 
2714                 if(proto == PPP_CCP)
 
2715                         mis->compflags &= ~(SC_DECOMP_ON|SC_COMP_ON);           
 
2717                         is->compflags &= ~(SC_LINK_DECOMP_ON|SC_LINK_COMP_ON);          
 
2720                 /* if we RECEIVE an ackowledge we enable the decompressor */
 
2721                 if(is->debug & 0x10)
 
2722                         printk(KERN_DEBUG "Enable decompression here!\n");
 
2723                 if(proto == PPP_CCP) {
 
2724                         if (!mis->decompressor)
 
2726                         mis->compflags |= SC_DECOMP_ON;
 
2728                         if (!is->decompressor)
 
2730                         is->compflags |= SC_LINK_DECOMP_ON;
 
2735                 printk(KERN_DEBUG "Received ResetAck from peer\n");
 
2736                 len = (skb->data[2] << 8) | skb->data[3];
 
2739                 if(proto == PPP_CCP) {
 
2740                         /* If a reset Ack was outstanding for this id, then
 
2741                            clean up the state engine */
 
2742                         isdn_ppp_ccp_reset_ack_rcvd(mis, skb->data[1]);
 
2743                         if(mis->decompressor && mis->decomp_stat)
 
2745                                         reset(mis->decomp_stat,
 
2748                                               len ? &skb->data[4] : NULL,
 
2750                         /* TODO: This is not easy to decide here */
 
2751                         mis->compflags &= ~SC_DECOMP_DISCARD;
 
2754                         isdn_ppp_ccp_reset_ack_rcvd(is, skb->data[1]);
 
2755                         if(is->link_decompressor && is->link_decomp_stat)
 
2756                                 is->link_decompressor->
 
2757                                         reset(is->link_decomp_stat,
 
2760                                               len ? &skb->data[4] : NULL,
 
2762                         /* TODO: neither here */
 
2763                         is->compflags &= ~SC_LINK_DECOMP_DISCARD;
 
2768                 printk(KERN_DEBUG "Received ResetReq from peer\n");
 
2769                 /* Receiving a ResetReq means we must reset our compressor */
 
2770                 /* Set up reset params for the reset entry */
 
2771                 memset(&rsparm, 0, sizeof(rsparm));
 
2772                 rsparm.data = rsdata;
 
2773                 rsparm.maxdlen = IPPP_RESET_MAXDATABYTES; 
 
2774                 /* Isolate data length */
 
2775                 len = (skb->data[2] << 8) | skb->data[3];
 
2777                 if(proto == PPP_CCP) {
 
2778                         if(mis->compressor && mis->comp_stat)
 
2780                                         reset(mis->comp_stat,
 
2783                                               len ? &skb->data[4] : NULL,
 
2787                         if(is->link_compressor && is->link_comp_stat)
 
2788                                 is->link_compressor->
 
2789                                         reset(is->link_comp_stat,
 
2792                                               len ? &skb->data[4] : NULL,
 
2795                 /* Ack the Req as specified by rsparm */
 
2797                         /* Compressor reset handler decided how to answer */
 
2799                                 /* We should send a Frame */
 
2800                                 isdn_ppp_ccp_xmit_reset(is, proto, CCP_RESETACK,
 
2801                                                         rsparm.idval ? rsparm.id
 
2808                                 printk(KERN_DEBUG "ResetAck suppressed\n");
 
2811                         /* We answer with a straight reflected Ack */
 
2812                         isdn_ppp_ccp_xmit_reset(is, proto, CCP_RESETACK,
 
2814                                                 len ? &skb->data[4] : NULL,
 
2823  * Daemon sends a CCP frame ...
 
2826 /* TODO: Clean this up with new Reset semantics */
 
2828 /* I believe the CCP handling as-is is done wrong. Compressed frames
 
2829  * should only be sent/received after CCP reaches UP state, which means
 
2830  * both sides have sent CONF_ACK. Currently, we handle both directions
 
2831  * independently, which means we may accept compressed frames too early
 
2832  * (supposedly not a problem), but may also mean we send compressed frames
 
2833  * too early, which may turn out to be a problem.
 
2834  * This part of state machine should actually be handled by (i)pppd, but
 
2835  * that's too big of a change now. --kai
 
2838 /* Actually, we might turn this into an advantage: deal with the RFC in
 
2839  * the old tradition of beeing generous on what we accept, but beeing
 
2840  * strict on what we send. Thus we should just
 
2841  * - accept compressed frames as soon as decompression is negotiated
 
2842  * - send compressed frames only when decomp *and* comp are negotiated
 
2843  * - drop rx compressed frames if we cannot decomp (instead of pushing them
 
2845  * and I tried to modify this file according to that. --abp
 
2848 static void isdn_ppp_send_ccp(isdn_net_dev *net_dev, isdn_net_local *lp, struct sk_buff *skb)
 
2850         struct ippp_struct *mis,*is;
 
2851         int proto, slot = lp->ppp_slot;
 
2852         unsigned char *data;
 
2854         if(!skb || skb->len < 3)
 
2856         if (slot < 0 || slot >= ISDN_MAX_CHANNELS) {
 
2857                 printk(KERN_ERR "%s: lp->ppp_slot(%d) out of range\n",
 
2861         is = ippp_table[slot];
 
2862         /* Daemon may send with or without address and control field comp */
 
2864         if(!(is->pppcfg & SC_COMP_AC) && data[0] == 0xff && data[1] == 0x03) {
 
2870         proto = ((int)data[0]<<8)+data[1];
 
2871         if(proto != PPP_CCP && proto != PPP_CCPFRAG)
 
2874         printk(KERN_DEBUG "Received CCP frame from daemon:\n");
 
2875         isdn_ppp_frame_log("ccp-xmit", skb->data, skb->len, 32, is->unit,lp->ppp_slot);
 
2878                 slot = ISDN_MASTER_PRIV(lp)->ppp_slot;
 
2879                 if (slot < 0 || slot >= ISDN_MAX_CHANNELS) {
 
2880                         printk(KERN_ERR "%s: slot(%d) out of range\n",
 
2884                 mis = ippp_table[slot];
 
2888                 printk(KERN_DEBUG "isdn_ppp: Ouch! Master CCP sends on slave slot!\n");
 
2892                 if(is->debug & 0x10)
 
2893                         printk(KERN_DEBUG "Disable decompression here!\n");
 
2894                 if(proto == PPP_CCP)
 
2895                         is->compflags &= ~SC_DECOMP_ON;
 
2897                         is->compflags &= ~SC_LINK_DECOMP_ON;
 
2901                 if(is->debug & 0x10)
 
2902                         printk(KERN_DEBUG "Disable (de)compression here!\n");
 
2903                 if(proto == PPP_CCP)
 
2904                         is->compflags &= ~(SC_DECOMP_ON|SC_COMP_ON);
 
2906                         is->compflags &= ~(SC_LINK_DECOMP_ON|SC_LINK_COMP_ON);
 
2909                 /* if we SEND an ackowledge we can/must enable the compressor */
 
2910                 if(is->debug & 0x10)
 
2911                         printk(KERN_DEBUG "Enable compression here!\n");
 
2912                 if(proto == PPP_CCP) {
 
2913                         if (!is->compressor)
 
2915                         is->compflags |= SC_COMP_ON;
 
2917                         if (!is->compressor)
 
2919                         is->compflags |= SC_LINK_COMP_ON;
 
2923                 /* If we send a ACK we should reset our compressor */
 
2924                 if(is->debug & 0x10)
 
2925                         printk(KERN_DEBUG "Reset decompression state here!\n");
 
2926                 printk(KERN_DEBUG "ResetAck from daemon passed by\n");
 
2927                 if(proto == PPP_CCP) {
 
2928                         /* link to master? */
 
2929                         if(is->compressor && is->comp_stat)
 
2930                                 is->compressor->reset(is->comp_stat, 0, 0,
 
2932                         is->compflags &= ~SC_COMP_DISCARD;      
 
2935                         if(is->link_compressor && is->link_comp_stat)
 
2936                                 is->link_compressor->reset(is->link_comp_stat,
 
2937                                                            0, 0, NULL, 0, NULL);
 
2938                         is->compflags &= ~SC_LINK_COMP_DISCARD; 
 
2942                 /* Just let it pass by */
 
2943                 printk(KERN_DEBUG "ResetReq from daemon passed by\n");
 
2948 int isdn_ppp_register_compressor(struct isdn_ppp_compressor *ipc)
 
2950         ipc->next = ipc_head;
 
2953                 ipc_head->prev = ipc;
 
2959 int isdn_ppp_unregister_compressor(struct isdn_ppp_compressor *ipc)
 
2962                 ipc->prev->next = ipc->next;
 
2964                 ipc_head = ipc->next;
 
2966                 ipc->next->prev = ipc->prev;
 
2967         ipc->prev = ipc->next = NULL;
 
2971 static int isdn_ppp_set_compressor(struct ippp_struct *is, struct isdn_ppp_comp_data *data)
 
2973         struct isdn_ppp_compressor *ipc = ipc_head;
 
2976         int num = data->num;
 
2978         if(is->debug & 0x10)
 
2979                 printk(KERN_DEBUG "[%d] Set %s type %d\n",is->unit,
 
2980                         (data->flags&IPPP_COMP_FLAG_XMIT)?"compressor":"decompressor",num);
 
2982         /* If is has no valid reset state vector, we cannot allocate a
 
2983            decompressor. The decompressor would cause reset transactions
 
2984            sooner or later, and they need that vector. */
 
2986         if(!(data->flags & IPPP_COMP_FLAG_XMIT) && !is->reset) {
 
2987                 printk(KERN_ERR "ippp_ccp: no reset data structure - can't"
 
2988                        " allow decompression.\n");
 
2993                 if(ipc->num == num) {
 
2994                         stat = ipc->alloc(data);
 
2996                                 ret = ipc->init(stat,data,is->unit,0);
 
2998                                         printk(KERN_ERR "Can't init (de)compression!\n");
 
3005                                 printk(KERN_ERR "Can't alloc (de)compression!\n");
 
3009                         if(data->flags & IPPP_COMP_FLAG_XMIT) {
 
3010                                 if(data->flags & IPPP_COMP_FLAG_LINK) {
 
3011                                         if(is->link_comp_stat)
 
3012                                                 is->link_compressor->free(is->link_comp_stat);
 
3013                                         is->link_comp_stat = stat;
 
3014                                         is->link_compressor = ipc;
 
3018                                                 is->compressor->free(is->comp_stat);
 
3019                                         is->comp_stat = stat;
 
3020                                         is->compressor = ipc;
 
3024                                 if(data->flags & IPPP_COMP_FLAG_LINK) {
 
3025                                         if(is->link_decomp_stat)
 
3026                                                 is->link_decompressor->free(is->link_decomp_stat);
 
3027                                         is->link_decomp_stat = stat;
 
3028                                         is->link_decompressor = ipc;
 
3032                                                 is->decompressor->free(is->decomp_stat);
 
3033                                         is->decomp_stat = stat;
 
3034                                         is->decompressor = ipc;