cregit-Linux how code gets into the kernel

Release 4.7 drivers/isdn/hisax/isdnl2.c

/* $Id: isdnl2.c,v 2.30.2.4 2004/02/11 13:21:34 keil Exp $
 *
 * Author       Karsten Keil
 *              based on the teles driver from Jan den Ouden
 * Copyright    by Karsten Keil      <keil@isdn4linux.de>
 *
 * This software may be used and distributed according to the terms
 * of the GNU General Public License, incorporated herein by reference.
 *
 * For changes and modifications please read
 * Documentation/isdn/HiSax.cert
 *
 * Thanks to    Jan den Ouden
 *              Fritz Elfert
 *
 */

#include <linux/init.h>
#include <linux/gfp.h>
#include "hisax.h"
#include "isdnl2.h"


const char *l2_revision = "$Revision: 2.30.2.4 $";

static void l2m_debug(struct FsmInst *fi, char *fmt, ...);


static struct Fsm l2fsm;

enum {
	
ST_L2_1,
	
ST_L2_2,
	
ST_L2_3,
	
ST_L2_4,
	
ST_L2_5,
	
ST_L2_6,
	
ST_L2_7,
	
ST_L2_8,
};


#define L2_STATE_COUNT (ST_L2_8 + 1)


static char *strL2State[] =
{
	"ST_L2_1",
	"ST_L2_2",
	"ST_L2_3",
	"ST_L2_4",
	"ST_L2_5",
	"ST_L2_6",
	"ST_L2_7",
	"ST_L2_8",
};

enum {
	
EV_L2_UI,
	
EV_L2_SABME,
	
EV_L2_DISC,
	
EV_L2_DM,
	
EV_L2_UA,
	
EV_L2_FRMR,
	
EV_L2_SUPER,
	
EV_L2_I,
	
EV_L2_DL_DATA,
	
EV_L2_ACK_PULL,
	
EV_L2_DL_UNIT_DATA,
	
EV_L2_DL_ESTABLISH_REQ,
	
EV_L2_DL_RELEASE_REQ,
	
EV_L2_MDL_ASSIGN,
	
EV_L2_MDL_REMOVE,
	
EV_L2_MDL_ERROR,
	
EV_L1_DEACTIVATE,
	
EV_L2_T200,
	
EV_L2_T203,
	
EV_L2_SET_OWN_BUSY,
	
EV_L2_CLEAR_OWN_BUSY,
	
EV_L2_FRAME_ERROR,
};


#define L2_EVENT_COUNT (EV_L2_FRAME_ERROR + 1)


static char *strL2Event[] =
{
	"EV_L2_UI",
	"EV_L2_SABME",
	"EV_L2_DISC",
	"EV_L2_DM",
	"EV_L2_UA",
	"EV_L2_FRMR",
	"EV_L2_SUPER",
	"EV_L2_I",
	"EV_L2_DL_DATA",
	"EV_L2_ACK_PULL",
	"EV_L2_DL_UNIT_DATA",
	"EV_L2_DL_ESTABLISH_REQ",
	"EV_L2_DL_RELEASE_REQ",
	"EV_L2_MDL_ASSIGN",
	"EV_L2_MDL_REMOVE",
	"EV_L2_MDL_ERROR",
	"EV_L1_DEACTIVATE",
	"EV_L2_T200",
	"EV_L2_T203",
	"EV_L2_SET_OWN_BUSY",
	"EV_L2_CLEAR_OWN_BUSY",
	"EV_L2_FRAME_ERROR",
};

static int l2addrsize(struct Layer2 *l2);


static void set_peer_busy(struct Layer2 *l2) { test_and_set_bit(FLG_PEER_BUSY, &l2->flag); if (!skb_queue_empty(&l2->i_queue) || !skb_queue_empty(&l2->ui_queue)) test_and_set_bit(FLG_L2BLOCK, &l2->flag); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git4792.16%375.00%
david s. millerdavid s. miller47.84%125.00%
Total51100.00%4100.00%


static void clear_peer_busy(struct Layer2 *l2) { if (test_and_clear_bit(FLG_PEER_BUSY, &l2->flag)) test_and_clear_bit(FLG_L2BLOCK, &l2->flag); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git33100.00%1100.00%
Total33100.00%1100.00%


static void InitWin(struct Layer2 *l2) { int i; for (i = 0; i < MAX_WINDOW; i++) l2->windowar[i] = NULL; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git36100.00%2100.00%
Total36100.00%2100.00%


static int freewin1(struct Layer2 *l2) { int i, cnt = 0; for (i = 0; i < MAX_WINDOW; i++) { if (l2->windowar[i]) { cnt++; dev_kfree_skb(l2->windowar[i]); l2->windowar[i] = NULL; } } return cnt; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git69100.00%3100.00%
Total69100.00%3100.00%


static inline void freewin(struct PStack *st) { freewin1(&st->l2); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git1995.00%150.00%
adrian bunkadrian bunk15.00%150.00%
Total20100.00%2100.00%


static void ReleaseWin(struct Layer2 *l2) { int cnt; if ((cnt = freewin1(l2))) printk(KERN_WARNING "isdl2 freed %d skbuffs in release\n", cnt); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git33100.00%2100.00%
Total33100.00%2100.00%


static inline unsigned int cansend(struct PStack *st) { unsigned int p1; if (test_bit(FLG_MOD128, &st->l2.flag)) p1 = (st->l2.vs - st->l2.va) % 128; else p1 = (st->l2.vs - st->l2.va) % 8; return ((p1 < st->l2.window) && !test_bit(FLG_PEER_BUSY, &st->l2.flag)); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git9398.94%375.00%
adrian bunkadrian bunk11.06%125.00%
Total94100.00%4100.00%


static inline void clear_exception(struct Layer2 *l2) { test_and_clear_bit(FLG_ACK_PEND, &l2->flag); test_and_clear_bit(FLG_REJEXC, &l2->flag); test_and_clear_bit(FLG_OWN_BUSY, &l2->flag); clear_peer_busy(l2); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git4697.87%266.67%
adrian bunkadrian bunk12.13%133.33%
Total47100.00%3100.00%


static inline int l2headersize(struct Layer2 *l2, int ui) { return (((test_bit(FLG_MOD128, &l2->flag) && (!ui)) ? 2 : 1) + (test_bit(FLG_LAPD, &l2->flag) ? 2 : 1)); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git5596.49%250.00%
adrian bunkadrian bunk11.75%125.00%
andrew mortonandrew morton11.75%125.00%
Total57100.00%4100.00%


inline int l2addrsize(struct Layer2 *l2) { return (test_bit(FLG_LAPD, &l2->flag) ? 2 : 1); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git2796.43%266.67%
andrew mortonandrew morton13.57%133.33%
Total28100.00%3100.00%


static int sethdraddr(struct Layer2 *l2, u_char *header, int rsp) { u_char *ptr = header; int crbit = rsp; if (test_bit(FLG_LAPD, &l2->flag)) { *ptr++ = (l2->sap << 2) | (rsp ? 2 : 0); *ptr++ = (l2->tei << 1) | 1; return (2); } else { if (test_bit(FLG_ORIG, &l2->flag)) crbit = !crbit; if (crbit) *ptr++ = 1; else *ptr++ = 3; return (1); } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git12298.39%375.00%
andrew mortonandrew morton21.61%125.00%
Total124100.00%4100.00%


static inline void enqueue_super(struct PStack *st, struct sk_buff *skb) { if (test_bit(FLG_LAPB, &st->l2.flag)) st->l1.bcs->tx_cnt += skb->len; st->l2.l2l1(st, PH_DATA | REQUEST, skb); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git5289.66%360.00%
andrew mortonandrew morton58.62%120.00%
jesper juhljesper juhl11.72%120.00%
Total58100.00%5100.00%

#define enqueue_ui(a, b) enqueue_super(a, b)
static inline int IsUI(u_char *data) { return ((data[0] & 0xef) == UI); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git2392.00%250.00%
adrian bunkadrian bunk14.00%125.00%
andrew mortonandrew morton14.00%125.00%
Total25100.00%4100.00%


static inline int IsUA(u_char *data) { return ((data[0] & 0xef) == UA); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git2392.00%250.00%
andrew mortonandrew morton14.00%125.00%
adrian bunkadrian bunk14.00%125.00%
Total25100.00%4100.00%


static inline int IsDM(u_char *data) { return ((data[0] & 0xef) == DM); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git2392.00%360.00%
adrian bunkadrian bunk14.00%120.00%
andrew mortonandrew morton14.00%120.00%
Total25100.00%5100.00%


static inline int IsDISC(u_char *data) { return ((data[0] & 0xef) == DISC); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git2392.00%250.00%
andrew mortonandrew morton14.00%125.00%
adrian bunkadrian bunk14.00%125.00%
Total25100.00%4100.00%


static inline int IsSFrame(u_char *data, struct PStack *st) { register u_char d = *data; if (!test_bit(FLG_MOD128, &st->l2.flag)) d &= 0xf; return (((d & 0xf3) == 1) && ((d & 0x0c) != 0x0c)); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git6295.38%360.00%
andrew mortonandrew morton23.08%120.00%
adrian bunkadrian bunk11.54%120.00%
Total65100.00%5100.00%


static inline int IsSABME(u_char *data, struct PStack *st) { u_char d = data[0] & ~0x10; return (test_bit(FLG_MOD128, &st->l2.flag) ? d == SABME : d == SABM); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git4794.00%571.43%
andrew mortonandrew morton24.00%114.29%
adrian bunkadrian bunk12.00%114.29%
Total50100.00%7100.00%


static inline int IsREJ(u_char *data, struct PStack *st) { return (test_bit(FLG_MOD128, &st->l2.flag) ? data[0] == REJ : (data[0] & 0xf) == REJ); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git4795.92%466.67%
adrian bunkadrian bunk12.04%116.67%
andrew mortonandrew morton12.04%116.67%
Total49100.00%6100.00%


static inline int IsFRMR(u_char *data) { return ((data[0] & 0xef) == FRMR); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git2392.00%250.00%
andrew mortonandrew morton14.00%125.00%
adrian bunkadrian bunk14.00%125.00%
Total25100.00%4100.00%


static inline int IsRNR(u_char *data, struct PStack *st) { return (test_bit(FLG_MOD128, &st->l2.flag) ? data[0] == RNR : (data[0] & 0xf) == RNR); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git4795.92%360.00%
adrian bunkadrian bunk12.04%120.00%
andrew mortonandrew morton12.04%120.00%
Total49100.00%5100.00%


static int iframe_error(struct PStack *st, struct sk_buff *skb) { int i = l2addrsize(&st->l2) + (test_bit(FLG_MOD128, &st->l2.flag) ? 2 : 1); int rsp = *skb->data & 0x2; if (test_bit(FLG_ORIG, &st->l2.flag)) rsp = !rsp; if (rsp) return 'L'; if (skb->len < i) return 'N'; if ((skb->len - i) > st->l2.maxlen) return 'O'; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git11298.25%571.43%
adrian bunkadrian bunk10.88%114.29%
andrew mortonandrew morton10.88%114.29%
Total114100.00%7100.00%


static int super_error(struct PStack *st, struct sk_buff *skb) { if (skb->len != l2addrsize(&st->l2) + (test_bit(FLG_MOD128, &st->l2.flag) ? 2 : 1)) return 'N'; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git5398.15%375.00%
adrian bunkadrian bunk11.85%125.00%
Total54100.00%4100.00%


static int unnum_error(struct PStack *st, struct sk_buff *skb, int wantrsp) { int rsp = (*skb->data & 0x2) >> 1; if (test_bit(FLG_ORIG, &st->l2.flag)) rsp = !rsp; if (rsp != wantrsp) return 'L'; if (skb->len != l2addrsize(&st->l2) + 1) return 'N'; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git8298.80%375.00%
adrian bunkadrian bunk11.20%125.00%
Total83100.00%4100.00%


static int UI_error(struct PStack *st, struct sk_buff *skb) { int rsp = *skb->data & 0x2; if (test_bit(FLG_ORIG, &st->l2.flag)) rsp = !rsp; if (rsp) return 'L'; if (skb->len > st->l2.maxlen + l2addrsize(&st->l2) + 1) return 'O'; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git7998.75%480.00%
adrian bunkadrian bunk11.25%120.00%
Total80100.00%5100.00%


static int FRMR_error(struct PStack *st, struct sk_buff *skb) { int headers = l2addrsize(&st->l2) + 1; u_char *datap = skb->data + headers; int rsp = *skb->data & 0x2; if (test_bit(FLG_ORIG, &st->l2.flag)) rsp = !rsp; if (!rsp) return 'L'; if (test_bit(FLG_MOD128, &st->l2.flag)) { if (skb->len < headers + 5) return 'N'; else l2m_debug(&st->l2.l2m, "FRMR information %2x %2x %2x %2x %2x", datap[0], datap[1], datap[2], datap[3], datap[4]); } else { if (skb->len < headers + 3) return 'N'; else l2m_debug(&st->l2.l2m, "FRMR information %2x %2x %2x", datap[0], datap[1], datap[2]); } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git18798.42%466.67%
andrew mortonandrew morton21.05%116.67%
adrian bunkadrian bunk10.53%116.67%
Total190100.00%6100.00%


static unsigned int legalnr(struct PStack *st, unsigned int nr) { struct Layer2 *l2 = &st->l2; if (test_bit(FLG_MOD128, &l2->flag)) return ((nr - l2->va) % 128) <= ((l2->vs - l2->va) % 128); else return ((nr - l2->va) % 8) <= ((l2->vs - l2->va) % 8); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git93100.00%4100.00%
Total93100.00%4100.00%


static void setva(struct PStack *st, unsigned int nr) { struct Layer2 *l2 = &st->l2; int len; u_long flags; spin_lock_irqsave(&l2->lock, flags); while (l2->va != nr) { (l2->va)++; if (test_bit(FLG_MOD128, &l2->flag)) l2->va %= 128; else l2->va %= 8; len = l2->windowar[l2->sow]->len; if (PACKET_NOACK == l2->windowar[l2->sow]->pkt_type) len = -1; dev_kfree_skb(l2->windowar[l2->sow]); l2->windowar[l2->sow] = NULL; l2->sow = (l2->sow + 1) % l2->window; spin_unlock_irqrestore(&l2->lock, flags); if (test_bit(FLG_LLI_L2WAKEUP, &st->lli.flag) && (len >= 0)) lli_writewakeup(st, len); spin_lock_irqsave(&l2->lock, flags); } spin_unlock_irqrestore(&l2->lock, flags); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git11051.89%457.14%
andrew mortonandrew morton10147.64%228.57%
kai germaschewskikai germaschewski10.47%114.29%
Total212100.00%7100.00%


static void send_uframe(struct PStack *st, u_char cmd, u_char cr) { struct sk_buff *skb; u_char tmp[MAX_HEADER_LEN]; int i; i = sethdraddr(&st->l2, tmp, cr); tmp[i++] = cmd; if (!(skb = alloc_skb(i, GFP_ATOMIC))) { printk(KERN_WARNING "isdl2 can't alloc sbbuff for send_uframe\n"); return; } memcpy(skb_put(skb, i), tmp, i); enqueue_super(st, skb); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git9496.91%375.00%
andrew mortonandrew morton33.09%125.00%
Total97100.00%4100.00%


static inline u_char get_PollFlag(struct PStack *st, struct sk_buff *skb) { return (skb->data[l2addrsize(&(st->l2))] & 0x10); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git3594.59%250.00%
adrian bunkadrian bunk12.70%125.00%
andrew mortonandrew morton12.70%125.00%
Total37100.00%4100.00%


static inline u_char get_PollFlagFree(struct PStack *st, struct sk_buff *skb) { u_char PF; PF = get_PollFlag(st, skb); dev_kfree_skb(skb); return (PF); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git3589.74%466.67%
adrian bunkadrian bunk25.13%116.67%
andrew mortonandrew morton25.13%116.67%
Total39100.00%6100.00%


static inline void start_t200(struct PStack *st, int i) { FsmAddTimer(&st->l2.t200, st->l2.T200, EV_L2_T200, NULL, i); test_and_set_bit(FLG_T200_RUN, &st->l2.flag); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git4897.96%375.00%
adrian bunkadrian bunk12.04%125.00%
Total49100.00%4100.00%


static inline void restart_t200(struct PStack *st, int i) { FsmRestartTimer(&st->l2.t200, st->l2.T200, EV_L2_T200, NULL, i); test_and_set_bit(FLG_T200_RUN, &st->l2.flag); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git4897.96%375.00%
adrian bunkadrian bunk12.04%125.00%
Total49100.00%4100.00%


static inline void stop_t200(struct PStack *st, int i) { if (test_and_clear_bit(FLG_T200_RUN, &st->l2.flag)) FsmDelTimer(&st->l2.t200, i); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git4097.56%480.00%
adrian bunkadrian bunk12.44%120.00%
Total41100.00%5100.00%


static inline void st5_dl_release_l2l3(struct PStack *st) { int pr; if (test_and_clear_bit(FLG_PEND_REL, &st->l2.flag)) pr = DL_RELEASE | CONFIRM; else pr = DL_RELEASE | INDICATION; st->l2.l2l3(st, pr, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git4989.09%360.00%
andrew mortonandrew morton59.09%120.00%
adrian bunkadrian bunk11.82%120.00%
Total55100.00%5100.00%


static inline void lapb_dl_release_l2l3(struct PStack *st, int f) { if (test_bit(FLG_LAPB, &st->l2.flag)) st->l2.l2l1(st, PH_DEACTIVATE | REQUEST, NULL); st->l2.l2l3(st, DL_RELEASE | f, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git4881.36%360.00%
andrew mortonandrew morton1016.95%120.00%
adrian bunkadrian bunk11.69%120.00%
Total59100.00%5100.00%


static void establishlink(struct FsmInst *fi) { struct PStack *st = fi->userdata; u_char cmd; clear_exception(&st->l2); st->l2.rc = 0; cmd = (test_bit(FLG_MOD128, &st->l2.flag) ? SABME : SABM) | 0x10; send_uframe(st, cmd, CMD); FsmDelTimer(&st->l2.t203, 1); restart_t200(st, 1); test_and_clear_bit(FLG_PEND_REL, &st->l2.flag); freewin(st); FsmChangeState(fi, ST_L2_5); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git11299.12%375.00%
andrew mortonandrew morton10.88%125.00%
Total113100.00%4100.00%


static void l2_mdl_error_ua(struct FsmInst *fi, int event, void *arg) { struct sk_buff *skb = arg; struct PStack *st = fi->userdata; if (get_PollFlagFree(st, skb)) st->ma.layer(st, MDL_ERROR | INDICATION, (void *) 'C'); else st->ma.layer(st, MDL_ERROR | INDICATION, (void *) 'D'); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git82100.00%5100.00%
Total82100.00%5100.00%


static void l2_mdl_error_dm(struct FsmInst *fi, int event, void *arg) { struct sk_buff *skb = arg; struct PStack *st = fi->userdata; if (get_PollFlagFree(st, skb)) st->ma.layer(st, MDL_ERROR | INDICATION, (void *) 'B'); else { st->ma.layer(st, MDL_ERROR | INDICATION, (void *) 'E'); establishlink(fi); test_and_clear_bit(FLG_L3_INIT, &st->l2.flag); } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git101100.00%5100.00%
Total101100.00%5100.00%


static void l2_st8_mdl_error_dm(struct FsmInst *fi, int event, void *arg) { struct sk_buff *skb = arg; struct PStack *st = fi->userdata; if (get_PollFlagFree(st, skb)) st->ma.layer(st, MDL_ERROR | INDICATION, (void *) 'B'); else { st->ma.layer(st, MDL_ERROR | INDICATION, (void *) 'E'); } establishlink(fi); test_and_clear_bit(FLG_L3_INIT, &st->l2.flag); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git101100.00%5100.00%
Total101100.00%5100.00%


static void l2_go_st3(struct FsmInst *fi, int event, void *arg) { FsmChangeState(fi, ST_L2_3); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git25100.00%2100.00%
Total25100.00%2100.00%


static void l2_mdl_assign(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; FsmChangeState(fi, ST_L2_3); st->l2.l2tei(st, MDL_ASSIGN | INDICATION, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git49100.00%5100.00%
Total49100.00%5100.00%


static void l2_queue_ui_assign(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; skb_queue_tail(&st->l2.ui_queue, skb); FsmChangeState(fi, ST_L2_2); st->l2.l2tei(st, MDL_ASSIGN | INDICATION, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git68100.00%4100.00%
Total68100.00%4100.00%


static void l2_queue_ui(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; skb_queue_tail(&st->l2.ui_queue, skb); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git46100.00%3100.00%
Total46100.00%3100.00%


static void tx_ui(struct PStack *st) { struct sk_buff *skb; u_char header[MAX_HEADER_LEN]; int i; i = sethdraddr(&(st->l2), header, CMD); header[i++] = UI; while ((skb = skb_dequeue(&st->l2.ui_queue))) { memcpy(skb_push(skb, i), header, i); enqueue_ui(st, skb); } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git8798.86%480.00%
andrew mortonandrew morton11.14%120.00%
Total88100.00%5100.00%


static void l2_send_ui(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; skb_queue_tail(&st->l2.ui_queue, skb); tx_ui(st); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git51100.00%3100.00%
Total51100.00%3100.00%


static void l2_got_ui(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; skb_pull(skb, l2headersize(&st->l2, 1)); st->l2.l2l3(st, DL_UNIT_DATA | INDICATION, skb); /* ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ * in states 1-3 for broadcast */ }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git6092.31%583.33%
andrew mortonandrew morton57.69%116.67%
Total65100.00%6100.00%


static void l2_establish(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; establishlink(fi); test_and_set_bit(FLG_L3_INIT, &st->l2.flag); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git44100.00%4100.00%
Total44100.00%4100.00%


static void l2_discard_i_setl3(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; skb_queue_purge(&st->l2.i_queue); test_and_set_bit(FLG_L3_INIT, &st->l2.flag); test_and_clear_bit(FLG_PEND_REL, &st->l2.flag); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git6098.36%266.67%
linus torvaldslinus torvalds11.64%133.33%
Total61100.00%3100.00%


static void l2_l3_reestablish(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; skb_queue_purge(&st->l2.i_queue); establishlink(fi); test_and_set_bit(FLG_L3_INIT, &st->l2.flag); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git5398.15%266.67%
linus torvaldslinus torvalds11.85%133.33%
Total54100.00%3100.00%


static void l2_release(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; st->l2.l2l3(st, DL_RELEASE | CONFIRM, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git3788.10%150.00%
andrew mortonandrew morton511.90%150.00%
Total42100.00%2100.00%


static void l2_pend_rel(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; test_and_set_bit(FLG_PEND_REL, &st->l2.flag); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git39100.00%1100.00%
Total39100.00%1100.00%


static void l2_disconnect(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; skb_queue_purge(&st->l2.i_queue); freewin(st); FsmChangeState(fi, ST_L2_6); st->l2.rc = 0; send_uframe(st, DISC | 0x10, CMD); FsmDelTimer(&st->l2.t203, 1); restart_t200(st, 2); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git8698.85%266.67%
linus torvaldslinus torvalds11.15%133.33%
Total87100.00%3100.00%


static void l2_start_multi(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; send_uframe(st, UA | get_PollFlagFree(st, skb), RSP); clear_exception(&st->l2); st->l2.vs = 0; st->l2.va = 0; st->l2.vr = 0; st->l2.sow = 0; FsmChangeState(fi, ST_L2_7); FsmAddTimer(&st->l2.t203, st->l2.T203, EV_L2_T203, NULL, 3); st->l2.l2l3(st, DL_ESTABLISH | INDICATION, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git12996.27%583.33%
andrew mortonandrew morton53.73%116.67%
Total134100.00%6100.00%


static void l2_send_UA(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; send_uframe(st, UA | get_PollFlagFree(st, skb), RSP); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git50100.00%4100.00%
Total50100.00%4100.00%


static void l2_send_DM(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; send_uframe(st, DM | get_PollFlagFree(st, skb), RSP); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git50100.00%4100.00%
Total50100.00%4100.00%


static void l2_restart_multi(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; int est = 0, state; state = fi->state; send_uframe(st, UA | get_PollFlagFree(st, skb), RSP); st->ma.layer(st, MDL_ERROR | INDICATION, (void *) 'F'); if (st->l2.vs != st->l2.va) { skb_queue_purge(&st->l2.i_queue); est = 1; } clear_exception(&st->l2); st->l2.vs = 0; st->l2.va = 0; st->l2.vr = 0; st->l2.sow = 0; FsmChangeState(fi, ST_L2_7); stop_t200(st, 3); FsmRestartTimer(&st->l2.t203, st->l2.T203, EV_L2_T203, NULL, 3); if (est) st->l2.l2l3(st, DL_ESTABLISH | INDICATION, NULL); if ((ST_L2_7 == state) || (ST_L2_8 == state)) if (!skb_queue_empty(&st->l2.i_queue) && cansend(st)) st->l2.l2l1(st, PH_PULL | REQUEST, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git24194.88%562.50%
andrew mortonandrew morton103.94%112.50%
david s. millerdavid s. miller20.79%112.50%
linus torvaldslinus torvalds10.39%112.50%
Total254100.00%8100.00%


static void l2_stop_multi(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; FsmChangeState(fi, ST_L2_4); FsmDelTimer(&st->l2.t203, 3); stop_t200(st, 4); send_uframe(st, UA | get_PollFlagFree(st, skb), RSP); skb_queue_purge(&st->l2.i_queue); freewin(st); lapb_dl_release_l2l3(st, INDICATION); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git9798.98%583.33%
linus torvaldslinus torvalds11.02%116.67%
Total98100.00%6100.00%


static void l2_connected(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; int pr = -1; if (!get_PollFlag(st, skb)) { l2_mdl_error_ua(fi, event, arg); return; } dev_kfree_skb(skb); if (test_and_clear_bit(FLG_PEND_REL, &st->l2.flag)) l2_disconnect(fi, event, arg); if (test_and_clear_bit(FLG_L3_INIT, &st->l2.flag)) { pr = DL_ESTABLISH | CONFIRM; } else if (st->l2.vs != st->l2.va) { skb_queue_purge(&st->l2.i_queue); pr = DL_ESTABLISH | INDICATION; } stop_t200(st, 5); st->l2.vr = 0; st->l2.vs = 0; st->l2.va = 0; st->l2.sow = 0; FsmChangeState(fi, ST_L2_7); FsmAddTimer(&st->l2.t203, st->l2.T203, EV_L2_T203, NULL, 4); if (pr != -1) st->l2.l2l3(st, pr, NULL); if (!skb_queue_empty(&st->l2.i_queue) && cansend(st)) st->l2.l2l1(st, PH_PULL | REQUEST, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git25294.74%660.00%
andrew mortonandrew morton103.76%110.00%
david s. millerdavid s. miller20.75%110.00%
adrian bunkadrian bunk10.38%110.00%
linus torvaldslinus torvalds10.38%110.00%
Total266100.00%10100.00%


static void l2_released(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; if (!get_PollFlag(st, skb)) { l2_mdl_error_ua(fi, event, arg); return; } dev_kfree_skb(skb); stop_t200(st, 6); lapb_dl_release_l2l3(st, CONFIRM); FsmChangeState(fi, ST_L2_4); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git8198.78%480.00%
adrian bunkadrian bunk11.22%120.00%
Total82100.00%5100.00%


static void l2_reestablish(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; if (!get_PollFlagFree(st, skb)) { establishlink(fi); test_and_set_bit(FLG_L3_INIT, &st->l2.flag); } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git63100.00%5100.00%
Total63100.00%5100.00%


static void l2_st5_dm_release(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; if (get_PollFlagFree(st, skb)) { stop_t200(st, 7); if (!test_bit(FLG_L3_INIT, &st->l2.flag)) skb_queue_purge(&st->l2.i_queue); if (test_bit(FLG_LAPB, &st->l2.flag)) st->l2.l2l1(st, PH_DEACTIVATE | REQUEST, NULL); st5_dl_release_l2l3(st); FsmChangeState(fi, ST_L2_4); } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git11294.92%466.67%
andrew mortonandrew morton54.24%116.67%
linus torvaldslinus torvalds10.85%116.67%
Total118100.00%6100.00%


static void l2_st6_dm_release(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; if (get_PollFlagFree(st, skb)) { stop_t200(st, 8); lapb_dl_release_l2l3(st, CONFIRM); FsmChangeState(fi, ST_L2_4); } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git66100.00%4100.00%
Total66100.00%4100.00%


static inline void enquiry_cr(struct PStack *st, u_char typ, u_char cr, u_char pf) { struct sk_buff *skb; struct Layer2 *l2; u_char tmp[MAX_HEADER_LEN]; int i; l2 = &st->l2; i = sethdraddr(l2, tmp, cr); if (test_bit(FLG_MOD128, &l2->flag)) { tmp[i++] = typ; tmp[i++] = (l2->vr << 1) | (pf ? 1 : 0); } else tmp[i++] = (l2->vr << 5) | typ | (pf ? 0x10 : 0); if (!(skb = alloc_skb(i, GFP_ATOMIC))) { printk(KERN_WARNING "isdl2 can't alloc sbbuff for enquiry_cr\n"); return; } memcpy(skb_put(skb, i), tmp, i); enqueue_super(st, skb); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git16697.08%250.00%
andrew mortonandrew morton42.34%125.00%
adrian bunkadrian bunk10.58%125.00%
Total171100.00%4100.00%


static inline void enquiry_response(struct PStack *st) { if (test_bit(FLG_OWN_BUSY, &st->l2.flag)) enquiry_cr(st, RNR, RSP, 1); else enquiry_cr(st, RR, RSP, 1); test_and_clear_bit(FLG_ACK_PEND, &st->l2.flag); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git6098.36%375.00%
adrian bunkadrian bunk11.64%125.00%
Total61100.00%4100.00%


static inline void transmit_enquiry(struct PStack *st) { if (test_bit(FLG_OWN_BUSY, &st->l2.flag)) enquiry_cr(st, RNR, CMD, 1); else enquiry_cr(st, RR, CMD, 1); test_and_clear_bit(FLG_ACK_PEND, &st->l2.flag); start_t200(st, 9); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git6798.53%480.00%
adrian bunkadrian bunk11.47%120.00%
Total68100.00%5100.00%


static void nrerrorrecovery(struct FsmInst *fi) { struct PStack *st = fi->userdata; st->ma.layer(st, MDL_ERROR | INDICATION, (void *) 'J'); establishlink(fi); test_and_clear_bit(FLG_L3_INIT, &st->l2.flag); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git56100.00%4100.00%
Total56100.00%4100.00%


static void invoke_retransmission(struct PStack *st, unsigned int nr) { struct Layer2 *l2 = &st->l2; u_int p1; u_long flags; spin_lock_irqsave(&l2->lock, flags); if (l2->vs != nr) { while (l2->vs != nr) { (l2->vs)--; if (test_bit(FLG_MOD128, &l2->flag)) { l2->vs %= 128; p1 = (l2->vs - l2->va) % 128; } else { l2->vs %= 8; p1 = (l2->vs - l2->va) % 8; } p1 = (p1 + l2->sow) % l2->window; if (test_bit(FLG_LAPB, &l2->flag)) st->l1.bcs->tx_cnt += l2->windowar[p1]->len + l2headersize(l2, 0); skb_queue_head(&l2->i_queue, l2->windowar[p1]); l2->windowar[p1] = NULL; } spin_unlock_irqrestore(&l2->lock, flags); st->l2.l2l1(st, PH_PULL | REQUEST, NULL); return; } spin_unlock_irqrestore(&l2->lock, flags); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git19582.98%583.33%
andrew mortonandrew morton4017.02%116.67%
Total235100.00%6100.00%


static void l2_st7_got_super(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; int PollFlag, rsp, typ = RR; unsigned int nr; struct Layer2 *l2 = &st->l2; rsp = *skb->data & 0x2; if (test_bit(FLG_ORIG, &l2->flag)) rsp = !rsp; skb_pull(skb, l2addrsize(l2)); if (IsRNR(skb->data, st)) { set_peer_busy(l2); typ = RNR; } else clear_peer_busy(l2); if (IsREJ(skb->data, st)) typ = REJ; if (test_bit(FLG_MOD128, &l2->flag)) { PollFlag = (skb->data[1] & 0x1) == 0x1; nr = skb->data[1] >> 1; } else { PollFlag = (skb->data[0] & 0x10); nr = (skb->data[0] >> 5) & 0x7; } dev_kfree_skb(skb); if (PollFlag) { if (rsp) st->ma.layer(st, MDL_ERROR | INDICATION, (void *) 'A'); else enquiry_response(st); } if (legalnr(st, nr)) { if (typ == REJ) { setva(st, nr); invoke_retransmission(st, nr); stop_t200(st, 10); if (FsmAddTimer(&st->l2.t203, st->l2.T203, EV_L2_T203, NULL, 6)) l2m_debug(&st->l2.l2m, "Restart T203 ST7 REJ"); } else if ((nr == l2->vs) && (typ == RR)) { setva(st, nr); stop_t200(st, 11); FsmRestartTimer(&st->l2.t203, st->l2.T203, EV_L2_T203, NULL, 7); } else if ((l2->va != nr) || (typ == RNR)) { setva(st, nr); if (typ != RR) FsmDelTimer(&st->l2.t203, 9); restart_t200(st, 12); } if (!skb_queue_empty(&st->l2.i_queue) && (typ == RR)) st->l2.l2l1(st, PH_PULL | REQUEST, NULL); } else nrerrorrecovery(fi); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git46198.29%562.50%
andrew mortonandrew morton51.07%112.50%
david s. millerdavid s. miller20.43%112.50%
adrian bunkadrian bunk10.21%112.50%
Total469100.00%8100.00%


static void l2_feed_i_if_reest(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; if (test_bit(FLG_LAPB, &st->l2.flag)) st->l1.bcs->tx_cnt += skb->len + l2headersize(&st->l2, 0); if (!test_bit(FLG_L3_INIT, &st->l2.flag)) skb_queue_tail(&st->l2.i_queue, skb); else dev_kfree_skb(skb); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git10299.03%375.00%
adrian bunkadrian bunk10.97%125.00%
Total103100.00%4100.00%


static void l2_feed_i_pull(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; if (test_bit(FLG_LAPB, &st->l2.flag)) st->l1.bcs->tx_cnt += skb->len + l2headersize(&st->l2, 0); skb_queue_tail(&st->l2.i_queue, skb); st->l2.l2l1(st, PH_PULL | REQUEST, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git9294.85%375.00%
andrew mortonandrew morton55.15%125.00%
Total97100.00%4100.00%


static void l2_feed_iqueue(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; if (test_bit(FLG_LAPB, &st->l2.flag)) st->l1.bcs->tx_cnt += skb->len + l2headersize(&st->l2, 0); skb_queue_tail(&st->l2.i_queue, skb); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git82100.00%3100.00%
Total82100.00%3100.00%


static void l2_got_iframe(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; struct Layer2 *l2 = &(st->l2); int PollFlag, ns, i; unsigned int nr; i = l2addrsize(l2); if (test_bit(FLG_MOD128, &l2->flag)) { PollFlag = ((skb->data[i + 1] & 0x1) == 0x1); ns = skb->data[i] >> 1; nr = (skb->data[i + 1] >> 1) & 0x7f; } else { PollFlag = (skb->data[i] & 0x10); ns = (skb->data[i] >> 1) & 0x7; nr = (skb->data[i] >> 5) & 0x7; } if (test_bit(FLG_OWN_BUSY, &l2->flag)) { dev_kfree_skb(skb); if (PollFlag) enquiry_response(st); } else if (l2->vr == ns) { (l2->vr)++; if (test_bit(FLG_MOD128, &l2->flag)) l2->vr %= 128; else l2->vr %= 8; test_and_clear_bit(FLG_REJEXC, &l2->flag); if (PollFlag) enquiry_response(st); else test_and_set_bit(FLG_ACK_PEND, &l2->flag); skb_pull(skb, l2headersize(l2, 0)); st->l2.l2l3(st, DL_DATA | INDICATION, skb); } else { /* n(s)!=v(r) */ dev_kfree_skb(skb); if (test_and_set_bit(FLG_REJEXC, &l2->flag)) { if (PollFlag) enquiry_response(st); } else { enquiry_cr(st, REJ, RSP, PollFlag); test_and_clear_bit(FLG_ACK_PEND, &l2->flag); } } if (legalnr(st, nr)) { if (!test_bit(FLG_PEER_BUSY, &st->l2.flag) && (fi->state == ST_L2_7)) { if (nr == st->l2.vs) { stop_t200(st, 13); FsmRestartTimer(&st->l2.t203, st->l2.T203, EV_L2_T203, NULL, 7); } else if (nr != st->l2.va) restart_t200(st, 14); } setva(st, nr); } else { nrerrorrecovery(fi); return; } if (!skb_queue_empty(&st->l2.i_queue) && (fi->state == ST_L2_7)) st->l2.l2l1(st, PH_PULL | REQUEST, NULL); if (test_and_clear_bit(FLG_ACK_PEND, &st->l2.flag)) enquiry_cr(st, RR, RSP, 0); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git51196.96%562.50%
andrew mortonandrew morton122.28%112.50%
adrian bunkadrian bunk20.38%112.50%
david s. millerdavid s. miller20.38%112.50%
Total527100.00%8100.00%


static void l2_got_tei(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; st->l2.tei = (long) arg; if (fi->state == ST_L2_3) { establishlink(fi); test_and_set_bit(FLG_L3_INIT, &st->l2.flag); } else FsmChangeState(fi, ST_L2_4); if (!skb_queue_empty(&st->l2.ui_queue)) tx_ui(st); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git8997.80%375.00%
david s. millerdavid s. miller22.20%125.00%
Total91100.00%4100.00%


static void l2_st5_tout_200(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; if (test_bit(FLG_LAPD, &st->l2.flag) && test_bit(FLG_DCHAN_BUSY, &st->l2.flag)) { FsmAddTimer(&st->l2.t200, st->l2.T200, EV_L2_T200, NULL, 9); } else if (st->l2.rc == st->l2.N200) { FsmChangeState(fi, ST_L2_4); test_and_clear_bit(FLG_T200_RUN, &st->l2.flag); skb_queue_purge(&st->l2.i_queue); st->ma.layer(st, MDL_ERROR | INDICATION, (void *) 'G'); if (test_bit(FLG_LAPB, &st->l2.flag)) st->l2.l2l1(st, PH_DEACTIVATE | REQUEST, NULL); st5_dl_release_l2l3(st); } else { st->l2.rc++; FsmAddTimer(&st->l2.t200, st->l2.T200, EV_L2_T200, NULL, 9); send_uframe(st, (test_bit(FLG_MOD128, &st->l2.flag) ? SABME : SABM) | 0x10, CMD); } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git22997.45%571.43%
andrew mortonandrew morton52.13%114.29%
linus torvaldslinus torvalds10.43%114.29%
Total235100.00%7100.00%


static void l2_st6_tout_200(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; if (test_bit(FLG_LAPD, &st->l2.flag) && test_bit(FLG_DCHAN_BUSY, &st->l2.flag)) { FsmAddTimer(&st->l2.t200, st->l2.T200, EV_L2_T200, NULL, 9); } else if (st->l2.rc == st->l2.N200) { FsmChangeState(fi, ST_L2_4); test_and_clear_bit(FLG_T200_RUN, &st->l2.flag); st->ma.layer(st, MDL_ERROR | INDICATION, (void *) 'H'); lapb_dl_release_l2l3(st, CONFIRM); } else { st->l2.rc++; FsmAddTimer(&st->l2.t200, st->l2.T200, EV_L2_T200, NULL, 9); send_uframe(st, DISC | 0x10, CMD); } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git182100.00%4100.00%
Total182100.00%4100.00%


static void l2_st7_tout_200(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; if (test_bit(FLG_LAPD, &st->l2.flag) && test_bit(FLG_DCHAN_BUSY, &st->l2.flag)) { FsmAddTimer(&st->l2.t200, st->l2.T200, EV_L2_T200, NULL, 9); return; } test_and_clear_bit(FLG_T200_RUN, &st->l2.flag); st->l2.rc = 0; FsmChangeState(fi, ST_L2_8); transmit_enquiry(st); st->l2.rc++; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git117100.00%4100.00%
Total117100.00%4100.00%


static void l2_st8_tout_200(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; if (test_bit(FLG_LAPD, &st->l2.flag) && test_bit(FLG_DCHAN_BUSY, &st->l2.flag)) { FsmAddTimer(&st->l2.t200, st->l2.T200, EV_L2_T200, NULL, 9); return; } test_and_clear_bit(FLG_T200_RUN, &st->l2.flag); if (st->l2.rc == st->l2.N200) { st->ma.layer(st, MDL_ERROR | INDICATION, (void *) 'I'); establishlink(fi); test_and_clear_bit(FLG_L3_INIT, &st->l2.flag); } else { transmit_enquiry(st); st->l2.rc++; } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git157100.00%4100.00%
Total157100.00%4100.00%


static void l2_st7_tout_203(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; if (test_bit(FLG_LAPD, &st->l2.flag) && test_bit(FLG_DCHAN_BUSY, &st->l2.flag)) { FsmAddTimer(&st->l2.t203, st->l2.T203, EV_L2_T203, NULL, 9); return; } FsmChangeState(fi, ST_L2_8); transmit_enquiry(st); st->l2.rc = 0; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git98100.00%3100.00%
Total98100.00%3100.00%


static void l2_pull_iqueue(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb, *nskb; struct Layer2 *l2 = &st->l2; u_char header[MAX_HEADER_LEN]; int i, hdr_space_needed; int unsigned p1; u_long flags; if (!cansend(st)) return; skb = skb_dequeue(&l2->i_queue); if (!skb) return; hdr_space_needed = l2headersize(l2, 0); nskb = skb_realloc_headroom(skb, hdr_space_needed); if (!nskb) { skb_queue_head(&l2->i_queue, skb); return; } spin_lock_irqsave(&l2->lock, flags); if (test_bit(FLG_MOD128, &l2->flag)) p1 = (l2->vs - l2->va) % 128; else p1 = (l2->vs - l2->va) % 8; p1 = (p1 + l2->sow) % l2->window; if (l2->windowar[p1]) { printk(KERN_WARNING "isdnl2 try overwrite ack queue entry %d\n", p1); dev_kfree_skb(l2->windowar[p1]); } l2->windowar[p1] = skb; i = sethdraddr(&st->l2, header, CMD); if (test_bit(FLG_MOD128, &l2->flag)) { header[i++] = l2->vs << 1; header[i++] = l2->vr << 1; l2->vs = (l2->vs + 1) % 128; } else { header[i++] = (l2->vr << 5) | (l2->vs << 1); l2->vs = (l2->vs + 1) % 8; } spin_unlock_irqrestore(&l2->lock, flags); memcpy(skb_push(nskb, i), header, i); st->l2.l2l1(st, PH_PULL | INDICATION, nskb); test_and_clear_bit(FLG_ACK_PEND, &st->l2.flag); if (!test_and_set_bit(FLG_T200_RUN, &st->l2.flag)) { FsmDelTimer(&st->l2.t203, 13); FsmAddTimer(&st->l2.t200, st->l2.T200, EV_L2_T200, NULL, 11); } if (!skb_queue_empty(&l2->i_queue) && cansend(st)) st->l2.l2l1(st, PH_PULL | REQUEST, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git39184.09%541.67%
david s. millerdavid s. miller316.67%325.00%
andrew mortonandrew morton214.52%18.33%
karsten keilkarsten keil153.23%216.67%
kai germaschewskikai germaschewski71.51%18.33%
Total465100.00%12100.00%


static void l2_st8_got_super(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; int PollFlag, rsp, rnr = 0; unsigned int nr; struct Layer2 *l2 = &st->l2; rsp = *skb->data & 0x2; if (test_bit(FLG_ORIG, &l2->flag)) rsp = !rsp; skb_pull(skb, l2addrsize(l2)); if (IsRNR(skb->data, st)) { set_peer_busy(l2); rnr = 1; } else clear_peer_busy(l2); if (test_bit(FLG_MOD128, &l2->flag)) { PollFlag = (skb->data[1] & 0x1) == 0x1; nr = skb->data[1] >> 1; } else { PollFlag = (skb->data[0] & 0x10); nr = (skb->data[0] >> 5) & 0x7; } dev_kfree_skb(skb); if (rsp && PollFlag) { if (legalnr(st, nr)) { if (rnr) { restart_t200(st, 15); } else { stop_t200(st, 16); FsmAddTimer(&l2->t203, l2->T203, EV_L2_T203, NULL, 5); setva(st, nr); } invoke_retransmission(st, nr); FsmChangeState(fi, ST_L2_7); if (!skb_queue_empty(&l2->i_queue) && cansend(st)) st->l2.l2l1(st, PH_PULL | REQUEST, NULL); } else nrerrorrecovery(fi); } else { if (!rsp && PollFlag) enquiry_response(st); if (legalnr(st, nr)) { setva(st, nr); } else nrerrorrecovery(fi); } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git34697.74%562.50%
andrew mortonandrew morton51.41%112.50%
david s. millerdavid s. miller20.56%112.50%
adrian bunkadrian bunk10.28%112.50%
Total354100.00%8100.00%


static void l2_got_FRMR(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; struct sk_buff *skb = arg; skb_pull(skb, l2addrsize(&st->l2) + 1); if (!(skb->data[0] & 1) || ((skb->data[0] & 3) == 1) || /* I or S */ (IsUA(skb->data) && (fi->state == ST_L2_7))) { st->ma.layer(st, MDL_ERROR | INDICATION, (void *) 'K'); establishlink(fi); test_and_clear_bit(FLG_L3_INIT, &st->l2.flag); } dev_kfree_skb(skb); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git13899.28%375.00%
adrian bunkadrian bunk10.72%125.00%
Total139100.00%4100.00%


static void l2_st24_tei_remove(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; skb_queue_purge(&st->l2.ui_queue); st->l2.tei = -1; FsmChangeState(fi, ST_L2_1); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git5298.11%266.67%
linus torvaldslinus torvalds11.89%133.33%
Total53100.00%3100.00%


static void l2_st3_tei_remove(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; skb_queue_purge(&st->l2.ui_queue); st->l2.tei = -1; st->l2.l2l3(st, DL_RELEASE | INDICATION, NULL); FsmChangeState(fi, ST_L2_1); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git6291.18%360.00%
andrew mortonandrew morton57.35%120.00%
linus torvaldslinus torvalds11.47%120.00%
Total68100.00%5100.00%


static void l2_st5_tei_remove(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; skb_queue_purge(&st->l2.i_queue); skb_queue_purge(&st->l2.ui_queue); freewin(st); st->l2.tei = -1; stop_t200(st, 17); st5_dl_release_l2l3(st); FsmChangeState(fi, ST_L2_1); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git7897.50%266.67%
linus torvaldslinus torvalds22.50%133.33%
Total80100.00%3100.00%


static void l2_st6_tei_remove(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; skb_queue_purge(&st->l2.ui_queue); st->l2.tei = -1; stop_t200(st, 18); st->l2.l2l3(st, DL_RELEASE | CONFIRM, NULL); FsmChangeState(fi, ST_L2_1); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git6992.00%360.00%
andrew mortonandrew morton56.67%120.00%
linus torvaldslinus torvalds11.33%120.00%
Total75100.00%5100.00%


static void l2_tei_remove(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; skb_queue_purge(&st->l2.i_queue); skb_queue_purge(&st->l2.ui_queue); freewin(st); st->l2.tei = -1; stop_t200(st, 17); FsmDelTimer(&st->l2.t203, 19); st->l2.l2l3(st, DL_RELEASE | INDICATION, NULL); FsmChangeState(fi, ST_L2_1); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git9593.14%360.00%
andrew mortonandrew morton54.90%120.00%
linus torvaldslinus torvalds21.96%120.00%
Total102100.00%5100.00%


static void l2_st14_persistent_da(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; skb_queue_purge(&st->l2.i_queue); skb_queue_purge(&st->l2.ui_queue); if (test_and_clear_bit(FLG_ESTAB_PEND, &st->l2.flag)) st->l2.l2l3(st, DL_RELEASE | INDICATION, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git6889.47%240.00%
andrew mortonandrew morton56.58%120.00%
linus torvaldslinus torvalds22.63%120.00%
jan engelhardtjan engelhardt11.32%120.00%
Total76100.00%5100.00%


static void l2_st5_persistent_da(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; skb_queue_purge(&st->l2.i_queue); skb_queue_purge(&st->l2.ui_queue); freewin(st); stop_t200(st, 19); st5_dl_release_l2l3(st); FsmChangeState(fi, ST_L2_4); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git6895.77%360.00%
linus torvaldslinus torvalds22.82%120.00%
jan engelhardtjan engelhardt11.41%120.00%
Total71100.00%5100.00%


static void l2_st6_persistent_da(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; skb_queue_purge(&st->l2.ui_queue); stop_t200(st, 20); st->l2.l2l3(st, DL_RELEASE | CONFIRM, NULL); FsmChangeState(fi, ST_L2_4); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git5989.39%350.00%
andrew mortonandrew morton57.58%116.67%
linus torvaldslinus torvalds11.52%116.67%
jan engelhardtjan engelhardt11.52%116.67%
Total66100.00%6100.00%


static void l2_persistent_da(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; skb_queue_purge(&st->l2.i_queue); skb_queue_purge(&st->l2.ui_queue); freewin(st); stop_t200(st, 19); FsmDelTimer(&st->l2.t203, 19); st->l2.l2l3(st, DL_RELEASE | INDICATION, NULL); FsmChangeState(fi, ST_L2_4); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git8591.40%350.00%
andrew mortonandrew morton55.38%116.67%
linus torvaldslinus torvalds22.15%116.67%
jan engelhardtjan engelhardt11.08%116.67%
Total93100.00%6100.00%


static void l2_set_own_busy(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; if (!test_and_set_bit(FLG_OWN_BUSY, &st->l2.flag)) { enquiry_cr(st, RNR, RSP, 0); test_and_clear_bit(FLG_ACK_PEND, &st->l2.flag); } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git67100.00%3100.00%
Total67100.00%3100.00%


static void l2_clear_own_busy(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; if (!test_and_clear_bit(FLG_OWN_BUSY, &st->l2.flag)) { enquiry_cr(st, RR, RSP, 0); test_and_clear_bit(FLG_ACK_PEND, &st->l2.flag); } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git67100.00%3100.00%
Total67100.00%3100.00%


static void l2_frame_error(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; st->ma.layer(st, MDL_ERROR | INDICATION, arg); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git42100.00%3100.00%
Total42100.00%3100.00%


static void l2_frame_error_reest(struct FsmInst *fi, int event, void *arg) { struct PStack *st = fi->userdata; st->ma.layer(st, MDL_ERROR | INDICATION, arg); establishlink(fi); test_and_clear_bit(FLG_L3_INIT, &st->l2.flag); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git59100.00%3100.00%
Total59100.00%3100.00%

static struct FsmNode L2FnList[] __initdata = { {ST_L2_1, EV_L2_DL_ESTABLISH_REQ, l2_mdl_assign}, {ST_L2_2, EV_L2_DL_ESTABLISH_REQ, l2_go_st3}, {ST_L2_4, EV_L2_DL_ESTABLISH_REQ, l2_establish}, {ST_L2_5, EV_L2_DL_ESTABLISH_REQ, l2_discard_i_setl3}, {ST_L2_7, EV_L2_DL_ESTABLISH_REQ, l2_l3_reestablish}, {ST_L2_8, EV_L2_DL_ESTABLISH_REQ, l2_l3_reestablish}, {ST_L2_4, EV_L2_DL_RELEASE_REQ, l2_release}, {ST_L2_5, EV_L2_DL_RELEASE_REQ, l2_pend_rel}, {ST_L2_7, EV_L2_DL_RELEASE_REQ, l2_disconnect}, {ST_L2_8, EV_L2_DL_RELEASE_REQ, l2_disconnect}, {ST_L2_5, EV_L2_DL_DATA, l2_feed_i_if_reest}, {ST_L2_7, EV_L2_DL_DATA, l2_feed_i_pull}, {ST_L2_8, EV_L2_DL_DATA, l2_feed_iqueue}, {ST_L2_1, EV_L2_DL_UNIT_DATA, l2_queue_ui_assign}, {ST_L2_2, EV_L2_DL_UNIT_DATA, l2_queue_ui}, {ST_L2_3, EV_L2_DL_UNIT_DATA, l2_queue_ui}, {ST_L2_4, EV_L2_DL_UNIT_DATA, l2_send_ui}, {ST_L2_5, EV_L2_DL_UNIT_DATA, l2_send_ui}, {ST_L2_6, EV_L2_DL_UNIT_DATA, l2_send_ui}, {ST_L2_7, EV_L2_DL_UNIT_DATA, l2_send_ui}, {ST_L2_8, EV_L2_DL_UNIT_DATA, l2_send_ui}, {ST_L2_1, EV_L2_MDL_ASSIGN, l2_got_tei}, {ST_L2_2, EV_L2_MDL_ASSIGN, l2_got_tei}, {ST_L2_3, EV_L2_MDL_ASSIGN, l2_got_tei}, {ST_L2_2, EV_L2_MDL_ERROR, l2_st24_tei_remove}, {ST_L2_3, EV_L2_MDL_ERROR, l2_st3_tei_remove}, {ST_L2_4, EV_L2_MDL_REMOVE, l2_st24_tei_remove}, {ST_L2_5, EV_L2_MDL_REMOVE, l2_st5_tei_remove}, {ST_L2_6, EV_L2_MDL_REMOVE, l2_st6_tei_remove}, {ST_L2_7, EV_L2_MDL_REMOVE, l2_tei_remove}, {ST_L2_8, EV_L2_MDL_REMOVE, l2_tei_remove}, {ST_L2_4, EV_L2_SABME, l2_start_multi}, {ST_L2_5, EV_L2_SABME, l2_send_UA}, {ST_L2_6, EV_L2_SABME, l2_send_DM}, {ST_L2_7, EV_L2_SABME, l2_restart_multi}, {ST_L2_8, EV_L2_SABME, l2_restart_multi}, {ST_L2_4, EV_L2_DISC, l2_send_DM}, {ST_L2_5, EV_L2_DISC, l2_send_DM}, {ST_L2_6, EV_L2_DISC, l2_send_UA}, {ST_L2_7, EV_L2_DISC, l2_stop_multi}, {ST_L2_8, EV_L2_DISC, l2_stop_multi}, {ST_L2_4, EV_L2_UA, l2_mdl_error_ua}, {ST_L2_5, EV_L2_UA, l2_connected}, {ST_L2_6, EV_L2_UA, l2_released}, {ST_L2_7, EV_L2_UA, l2_mdl_error_ua}, {ST_L2_8, EV_L2_UA, l2_mdl_error_ua}, {ST_L2_4, EV_L2_DM, l2_reestablish}, {ST_L2_5, EV_L2_DM, l2_st5_dm_release}, {ST_L2_6, EV_L2_DM, l2_st6_dm_release}, {ST_L2_7, EV_L2_DM, l2_mdl_error_dm}, {ST_L2_8, EV_L2_DM, l2_st8_mdl_error_dm}, {ST_L2_1, EV_L2_UI, l2_got_ui}, {ST_L2_2, EV_L2_UI, l2_got_ui}, {ST_L2_3, EV_L2_UI, l2_got_ui}, {ST_L2_4, EV_L2_UI, l2_got_ui}, {ST_L2_5, EV_L2_UI, l2_got_ui}, {ST_L2_6, EV_L2_UI, l2_got_ui}, {ST_L2_7, EV_L2_UI, l2_got_ui}, {ST_L2_8, EV_L2_UI, l2_got_ui}, {ST_L2_7, EV_L2_FRMR, l2_got_FRMR}, {ST_L2_8, EV_L2_FRMR, l2_got_FRMR}, {ST_L2_7, EV_L2_SUPER, l2_st7_got_super}, {ST_L2_8, EV_L2_SUPER, l2_st8_got_super}, {ST_L2_7, EV_L2_I, l2_got_iframe}, {ST_L2_8, EV_L2_I, l2_got_iframe}, {ST_L2_5, EV_L2_T200, l2_st5_tout_200}, {ST_L2_6, EV_L2_T200, l2_st6_tout_200}, {ST_L2_7, EV_L2_T200, l2_st7_tout_200}, {ST_L2_8, EV_L2_T200, l2_st8_tout_200}, {ST_L2_7, EV_L2_T203, l2_st7_tout_203}, {ST_L2_7, EV_L2_ACK_PULL, l2_pull_iqueue}, {ST_L2_7, EV_L2_SET_OWN_BUSY, l2_set_own_busy}, {ST_L2_8, EV_L2_SET_OWN_BUSY, l2_set_own_busy}, {ST_L2_7, EV_L2_CLEAR_OWN_BUSY, l2_clear_own_busy}, {ST_L2_8, EV_L2_CLEAR_OWN_BUSY, l2_clear_own_busy}, {ST_L2_4, EV_L2_FRAME_ERROR, l2_frame_error}, {ST_L2_5, EV_L2_FRAME_ERROR, l2_frame_error}, {ST_L2_6, EV_L2_FRAME_ERROR, l2_frame_error}, {ST_L2_7, EV_L2_FRAME_ERROR, l2_frame_error_reest}, {ST_L2_8, EV_L2_FRAME_ERROR, l2_frame_error_reest}, {ST_L2_1, EV_L1_DEACTIVATE, l2_st14_persistent_da}, {ST_L2_2, EV_L1_DEACTIVATE, l2_st24_tei_remove}, {ST_L2_3, EV_L1_DEACTIVATE, l2_st3_tei_remove}, {ST_L2_4, EV_L1_DEACTIVATE, l2_st14_persistent_da}, {ST_L2_5, EV_L1_DEACTIVATE, l2_st5_persistent_da}, {ST_L2_6, EV_L1_DEACTIVATE, l2_st6_persistent_da}, {ST_L2_7, EV_L1_DEACTIVATE, l2_persistent_da}, {ST_L2_8, EV_L1_DEACTIVATE, l2_persistent_da}, };
static void isdnl2_l1l2(struct PStack *st, int pr, void *arg) { struct sk_buff *skb = arg; u_char *datap; int ret = 1, len; int c = 0; switch (pr) { case (PH_DATA | INDICATION): datap = skb->data; len = l2addrsize(&st->l2); if (skb->len > len) datap += len; else { FsmEvent(&st->l2.l2m, EV_L2_FRAME_ERROR, (void *) 'N'); dev_kfree_skb(skb); return; } if (!(*datap & 1)) { /* I-Frame */ if (!(c = iframe_error(st, skb))) ret = FsmEvent(&st->l2.l2m, EV_L2_I, skb); } else if (IsSFrame(datap, st)) { /* S-Frame */ if (!(c = super_error(st, skb))) ret = FsmEvent(&st->l2.l2m, EV_L2_SUPER, skb); } else if (IsUI(datap)) { if (!(c = UI_error(st, skb))) ret = FsmEvent(&st->l2.l2m, EV_L2_UI, skb); } else if (IsSABME(datap, st)) { if (!(c = unnum_error(st, skb, CMD))) ret = FsmEvent(&st->l2.l2m, EV_L2_SABME, skb); } else if (IsUA(datap)) { if (!(c = unnum_error(st, skb, RSP))) ret = FsmEvent(&st->l2.l2m, EV_L2_UA, skb); } else if (IsDISC(datap)) { if (!(c = unnum_error(st, skb, CMD))) ret = FsmEvent(&st->l2.l2m, EV_L2_DISC, skb); } else if (IsDM(datap)) { if (!(c = unnum_error(st, skb, RSP))) ret = FsmEvent(&st->l2.l2m, EV_L2_DM, skb); } else if (IsFRMR(datap)) { if (!(c = FRMR_error(st, skb))) ret = FsmEvent(&st->l2.l2m, EV_L2_FRMR, skb); } else { FsmEvent(&st->l2.l2m, EV_L2_FRAME_ERROR, (void *) 'L'); dev_kfree_skb(skb); ret = 0; } if (c) { dev_kfree_skb(skb); FsmEvent(&st->l2.l2m, EV_L2_FRAME_ERROR, (void *)(long)c); ret = 0; } if (ret) dev_kfree_skb(skb); break; case (PH_PULL | CONFIRM): FsmEvent(&st->l2.l2m, EV_L2_ACK_PULL, arg); break; case (PH_PAUSE | INDICATION): test_and_set_bit(FLG_DCHAN_BUSY, &st->l2.flag); break; case (PH_PAUSE | CONFIRM): test_and_clear_bit(FLG_DCHAN_BUSY, &st->l2.flag); break; case (PH_ACTIVATE | CONFIRM): case (PH_ACTIVATE | INDICATION): test_and_set_bit(FLG_L1_ACTIV, &st->l2.flag); if (test_and_clear_bit(FLG_ESTAB_PEND, &st->l2.flag)) FsmEvent(&st->l2.l2m, EV_L2_DL_ESTABLISH_REQ, arg); break; case (PH_DEACTIVATE | INDICATION): case (PH_DEACTIVATE | CONFIRM): test_and_clear_bit(FLG_L1_ACTIV, &st->l2.flag); FsmEvent(&st->l2.l2m, EV_L1_DEACTIVATE, arg); break; default: l2m_debug(&st->l2.l2m, "l2 unknown pr %04x", pr); break; } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git68999.14%675.00%
adrian bunkadrian bunk40.58%112.50%
andrew mortonandrew morton20.29%112.50%
Total695100.00%8100.00%


static void isdnl2_l3l2(struct PStack *st, int pr, void *arg) { switch (pr) { case (DL_DATA | REQUEST): if (FsmEvent(&st->l2.l2m, EV_L2_DL_DATA, arg)) { dev_kfree_skb((struct sk_buff *) arg); } break; case (DL_UNIT_DATA | REQUEST): if (FsmEvent(&st->l2.l2m, EV_L2_DL_UNIT_DATA, arg)) { dev_kfree_skb((struct sk_buff *) arg); } break; case (DL_ESTABLISH | REQUEST): if (test_bit(FLG_L1_ACTIV, &st->l2.flag)) { if (test_bit(FLG_LAPD, &st->l2.flag) || test_bit(FLG_ORIG, &st->l2.flag)) { FsmEvent(&st->l2.l2m, EV_L2_DL_ESTABLISH_REQ, arg); } } else { if (test_bit(FLG_LAPD, &st->l2.flag) || test_bit(FLG_ORIG, &st->l2.flag)) { test_and_set_bit(FLG_ESTAB_PEND, &st->l2.flag); } st->l2.l2l1(st, PH_ACTIVATE, NULL); } break; case (DL_RELEASE | REQUEST): if (test_bit(FLG_LAPB, &st->l2.flag)) { st->l2.l2l1(st, PH_DEACTIVATE, NULL); } FsmEvent(&st->l2.l2m, EV_L2_DL_RELEASE_REQ, arg); break; case (MDL_ASSIGN | REQUEST): FsmEvent(&st->l2.l2m, EV_L2_MDL_ASSIGN, arg); break; case (MDL_REMOVE | REQUEST): FsmEvent(&st->l2.l2m, EV_L2_MDL_REMOVE, arg); break; case (MDL_ERROR | RESPONSE): FsmEvent(&st->l2.l2m, EV_L2_MDL_ERROR, arg); break; } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git32597.01%583.33%
andrew mortonandrew morton102.99%116.67%
Total335100.00%6100.00%


void releasestack_isdnl2(struct PStack *st) { FsmDelTimer(&st->l2.t200, 21); FsmDelTimer(&st->l2.t203, 16); skb_queue_purge(&st->l2.i_queue); skb_queue_purge(&st->l2.ui_queue); ReleaseWin(&st->l2); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git6096.77%583.33%
linus torvaldslinus torvalds23.23%116.67%
Total62100.00%6100.00%


static void l2m_debug(struct FsmInst *fi, char *fmt, ...) { va_list args; struct PStack *st = fi->userdata; va_start(args, fmt); VHiSax_putstatus(st->l1.hardware, st->l2.debug_id, fmt, args); va_end(args); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git60100.00%2100.00%
Total60100.00%2100.00%


void setstack_isdnl2(struct PStack *st, char *debug_id) { spin_lock_init(&st->l2.lock); st->l1.l1l2 = isdnl2_l1l2; st->l3.l3l2 = isdnl2_l3l2; skb_queue_head_init(&st->l2.i_queue); skb_queue_head_init(&st->l2.ui_queue); InitWin(&st->l2); st->l2.debug = 0; st->l2.l2m.fsm = &l2fsm; if (test_bit(FLG_LAPB, &st->l2.flag)) st->l2.l2m.state = ST_L2_4; else st->l2.l2m.state = ST_L2_1; st->l2.l2m.debug = 0; st->l2.l2m.userdata = st; st->l2.l2m.userint = 0; st->l2.l2m.printdebug = l2m_debug; strcpy(st->l2.debug_id, debug_id); FsmInitTimer(&st->l2.l2m, &st->l2.t200); FsmInitTimer(&st->l2.l2m, &st->l2.t203); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git19594.20%466.67%
andrew mortonandrew morton115.31%116.67%
linus torvaldslinus torvalds10.48%116.67%
Total207100.00%6100.00%


static void transl2_l3l2(struct PStack *st, int pr, void *arg) { switch (pr) { case (DL_DATA | REQUEST): case (DL_UNIT_DATA | REQUEST): st->l2.l2l1(st, PH_DATA | REQUEST, arg); break; case (DL_ESTABLISH | REQUEST): st->l2.l2l1(st, PH_ACTIVATE | REQUEST, NULL); break; case (DL_RELEASE | REQUEST): st->l2.l2l1(st, PH_DEACTIVATE | REQUEST, NULL); break; } }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git8585.00%150.00%
andrew mortonandrew morton1515.00%150.00%
Total100100.00%2100.00%


void setstack_transl2(struct PStack *st) { st->l3.l3l2 = transl2_l3l2; }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git1794.44%266.67%
andrew mortonandrew morton15.56%133.33%
Total18100.00%3100.00%


void releasestack_transl2(struct PStack *st) { }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git9100.00%1100.00%
Total9100.00%1100.00%


int __init Isdnl2New(void) { l2fsm.state_count = L2_STATE_COUNT; l2fsm.event_count = L2_EVENT_COUNT; l2fsm.strEvent = strL2Event; l2fsm.strState = strL2State; return FsmNew(&l2fsm, L2FnList, ARRAY_SIZE(L2FnList)); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git3984.78%250.00%
karsten keilkarsten keil48.70%125.00%
linus torvaldslinus torvalds36.52%125.00%
Total46100.00%4100.00%


void Isdnl2Free(void) { FsmFree(&l2fsm); }

Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git13100.00%1100.00%
Total13100.00%1100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git1111495.55%1035.71%
andrew mortonandrew morton3563.06%27.14%
david s. millerdavid s. miller470.40%310.71%
adrian bunkadrian bunk410.35%13.57%
linus torvaldslinus torvalds280.24%310.71%
karsten keilkarsten keil190.16%310.71%
jan engelhardtjan engelhardt100.09%13.57%
kai germaschewskikai germaschewski90.08%27.14%
joe perchesjoe perches30.03%13.57%
tejun heotejun heo30.03%13.57%
jesper juhljesper juhl10.01%13.57%
Total11631100.00%28100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}