taglinefilesource code
skb61drivers/net/3c501.cstatic int  el_start_xmit(struct sk_buff *skb, struct device *dev);
skb264drivers/net/3c501.cel_start_xmit(struct sk_buff *skb, struct device *dev)
skb289drivers/net/3c501.cif (skb == NULL) {
skb295drivers/net/3c501.cif (!skb->arp  &&  dev->rebuild_header(skb->data, dev)) {
skb296drivers/net/3c501.cskb->dev = dev;
skb297drivers/net/3c501.carp_queue (skb);
skb300drivers/net/3c501.cskb->arp=1;
skb302drivers/net/3c501.cif (skb->len <= 0)
skb306drivers/net/3c501.cprintk("%s: el_start_xmit(%d)...", dev->name, skb->len);
skb312drivers/net/3c501.cint gp_start = 0x800 - (ETH_ZLEN < skb->len ? skb->len : ETH_ZLEN);
skb313drivers/net/3c501.cunsigned char *buf = skb->data;
skb323drivers/net/3c501.coutsb(DATAPORT,buf,skb->len);
skb331drivers/net/3c501.cif (skb->free)
skb332drivers/net/3c501.ckfree_skb (skb, FREE_WRITE);
skb438drivers/net/3c501.cstruct sk_buff *skb;
skb454drivers/net/3c501.cskb = alloc_skb(sksize, GFP_ATOMIC);
skb456drivers/net/3c501.cif (skb == NULL) {
skb461drivers/net/3c501.cskb->mem_len = sksize;
skb462drivers/net/3c501.cskb->mem_addr = skb;
skb463drivers/net/3c501.cskb->len = pkt_len;
skb464drivers/net/3c501.cskb->dev = dev;
skb466drivers/net/3c501.cinsb(DATAPORT, skb->data, pkt_len);
skb469drivers/net/3c501.cnetif_rx(skb);
skb471drivers/net/3c501.cskb->lock = 0;
skb472drivers/net/3c501.cif (dev_rint((unsigned char*)skb, pkt_len, IN_SKBUFF, dev) != 0) {
skb473drivers/net/3c501.ckfree_skbmem(skb, sksize);
skb262drivers/net/3c507.cstatic int  el16_send_packet(struct sk_buff *skb, struct device *dev);
skb445drivers/net/3c507.cel16_send_packet(struct sk_buff *skb, struct device *dev)
skb480drivers/net/3c507.cif (skb == NULL) {
skb487drivers/net/3c507.cif (!skb->arp  &&  dev->rebuild_header(skb->data, dev)) {
skb488drivers/net/3c507.cskb->dev = dev;
skb489drivers/net/3c507.carp_queue (skb);
skb492drivers/net/3c507.cskb->arp=1;
skb498drivers/net/3c507.cshort length = ETH_ZLEN < skb->len ? skb->len : ETH_ZLEN;
skb499drivers/net/3c507.cunsigned char *buf = skb->data;
skb509drivers/net/3c507.cif (skb->free)
skb510drivers/net/3c507.ckfree_skb (skb, FREE_WRITE);
skb843drivers/net/3c507.cstruct sk_buff *skb;
skb847drivers/net/3c507.cskb = alloc_skb(sksize, GFP_ATOMIC);
skb848drivers/net/3c507.cif (skb == NULL) {
skb853drivers/net/3c507.cskb->mem_len = sksize;
skb854drivers/net/3c507.cskb->mem_addr = skb;
skb855drivers/net/3c507.cskb->len = pkt_len;
skb856drivers/net/3c507.cskb->dev = dev;
skb859drivers/net/3c507.cmemcpy(skb->data, data_frame + 5, pkt_len);
skb862drivers/net/3c507.cnetif_rx(skb);
skb864drivers/net/3c507.cskb->lock = 0;
skb865drivers/net/3c507.cif (dev_rint((unsigned char*)skb, pkt_len, IN_SKBUFF, dev) != 0) {
skb866drivers/net/3c507.ckfree_skbmem(skb, sksize);
skb76drivers/net/3c509.cstatic int el3_start_xmit(struct sk_buff *skb, struct device *dev);
skb344drivers/net/3c509.cel3_start_xmit(struct sk_buff *skb, struct device *dev)
skb363drivers/net/3c509.cif (skb == NULL) {
skb369drivers/net/3c509.cif (!skb->arp  &&  dev->rebuild_header(skb->data, dev)) {
skb370drivers/net/3c509.cskb->dev = dev;
skb371drivers/net/3c509.carp_queue (skb);
skb374drivers/net/3c509.cskb->arp=1;
skb376drivers/net/3c509.cif (skb->len <= 0)
skb381drivers/net/3c509.cdev->name, skb->len, inw(ioaddr + EL3_STATUS));
skb404drivers/net/3c509.coutw(skb->len, ioaddr + TX_FIFO);
skb407drivers/net/3c509.coutsl(ioaddr + TX_FIFO, skb->data, (skb->len + 3) >> 2);
skb417drivers/net/3c509.cif (skb->free)
skb418drivers/net/3c509.ckfree_skb (skb, FREE_WRITE);
skb567drivers/net/3c509.cstruct sk_buff *skb;
skb569drivers/net/3c509.cskb = alloc_skb(sksize, GFP_ATOMIC);
skb573drivers/net/3c509.cif (skb != NULL) {
skb574drivers/net/3c509.cskb->mem_len = sksize;
skb575drivers/net/3c509.cskb->mem_addr = skb;
skb576drivers/net/3c509.cskb->len = pkt_len;
skb577drivers/net/3c509.cskb->dev = dev;
skb580drivers/net/3c509.cinsl(ioaddr+RX_FIFO, skb->data,
skb584drivers/net/3c509.cnetif_rx(skb);
skb588drivers/net/3c509.cskb->lock = 0;
skb589drivers/net/3c509.cif (dev_rint((unsigned char *)skb, pkt_len,
skb604drivers/net/3c509.ckfree_s(skb, sksize);
skb126drivers/net/8390.cstatic int ei_start_xmit(struct sk_buff *skb, struct device *dev)
skb158drivers/net/8390.cif (skb == NULL) {
skb163drivers/net/8390.cif (!skb->arp  &&  dev->rebuild_header(skb->data, dev)) {
skb164drivers/net/8390.cskb->dev = dev;
skb165drivers/net/8390.carp_queue (skb);
skb168drivers/net/8390.cskb->arp=1;
skb170drivers/net/8390.cif (skb->len <= 0)
skb172drivers/net/8390.clength = skb->len;
skb222drivers/net/8390.cei_block_output(dev, length, skb->data, output_page);
skb236drivers/net/8390.cei_block_output(dev, length, skb->data,
skb242drivers/net/8390.cif (skb->free)
skb243drivers/net/8390.ckfree_skb (skb, FREE_WRITE);
skb483drivers/net/8390.cstruct sk_buff *skb;
skb485drivers/net/8390.cskb = alloc_skb(sksize, GFP_ATOMIC);
skb486drivers/net/8390.cif (skb == NULL) {
skb493drivers/net/8390.cskb->mem_len = sksize;
skb494drivers/net/8390.cskb->mem_addr = skb;
skb495drivers/net/8390.cskb->len = pkt_len;
skb496drivers/net/8390.cskb->dev = dev;
skb499drivers/net/8390.cei_block_input(dev, pkt_len, (char *) skb->data,
skb502drivers/net/8390.cnetif_rx(skb);
skb504drivers/net/8390.cskb->lock = 0;
skb505drivers/net/8390.cif (dev_rint((unsigned char*)skb, pkt_len, IN_SKBUFF, dev)) {
skb506drivers/net/8390.ckfree_skbmem(skb, sksize);
skb116drivers/net/at1700.cstatic int  net_send_packet(struct sk_buff *skb, struct device *dev);
skb367drivers/net/at1700.cnet_send_packet(struct sk_buff *skb, struct device *dev)
skb398drivers/net/at1700.cif (skb == NULL) {
skb405drivers/net/at1700.cif (!skb->arp  &&  dev->rebuild_header(skb->data, dev)) {
skb406drivers/net/at1700.cskb->dev = dev;
skb407drivers/net/at1700.carp_queue (skb);
skb410drivers/net/at1700.cskb->arp=1;
skb417drivers/net/at1700.cshort length = ETH_ZLEN < skb->len ? skb->len : ETH_ZLEN;
skb418drivers/net/at1700.cunsigned char *buf = skb->data;
skb422drivers/net/at1700.cskb->len);
skb446drivers/net/at1700.cif (skb->free)
skb447drivers/net/at1700.ckfree_skb (skb, FREE_WRITE);
skb532drivers/net/at1700.cstruct sk_buff *skb;
skb541drivers/net/at1700.cskb = alloc_skb(sksize, GFP_ATOMIC);
skb542drivers/net/at1700.cif (skb == NULL) {
skb549drivers/net/at1700.cskb->mem_len = sksize;
skb550drivers/net/at1700.cskb->mem_addr = skb;
skb551drivers/net/at1700.cskb->len = pkt_len;
skb552drivers/net/at1700.cskb->dev = dev;
skb555drivers/net/at1700.cinsw(ioaddr + DATAPORT, skb->data, (pkt_len + 1) >> 1);
skb561drivers/net/at1700.cprintk(" %02x", skb->data[i]);
skb566drivers/net/at1700.cnetif_rx(skb);
skb568drivers/net/at1700.cskb->lock = 0;
skb569drivers/net/at1700.cif (dev_rint((unsigned char*)skb, pkt_len, IN_SKBUFF, dev) != 0) {
skb570drivers/net/at1700.ckfree_s(skb, sksize);
skb142drivers/net/atp.cstatic int  net_send_packet(struct sk_buff *skb, struct device *dev);
skb449drivers/net/atp.cnet_send_packet(struct sk_buff *skb, struct device *dev)
skb473drivers/net/atp.cif (skb == NULL) {
skb480drivers/net/atp.cif (!skb->arp  &&  dev->rebuild_header(skb->data, dev)) {
skb481drivers/net/atp.cskb->dev = dev;
skb482drivers/net/atp.carp_queue (skb);
skb485drivers/net/atp.cskb->arp=1;
skb492drivers/net/atp.cshort length = ETH_ZLEN < skb->len ? skb->len : ETH_ZLEN;
skb493drivers/net/atp.cunsigned char *buf = skb->data;
skb521drivers/net/atp.cif (skb->free)
skb522drivers/net/atp.ckfree_skb (skb, FREE_WRITE);
skb676drivers/net/atp.cstruct sk_buff *skb;
skb678drivers/net/atp.cskb = alloc_skb(sksize, GFP_ATOMIC);
skb679drivers/net/atp.cif (skb == NULL) {
skb684drivers/net/atp.cskb->mem_len = sksize;
skb685drivers/net/atp.cskb->mem_addr = skb;
skb686drivers/net/atp.cskb->len = pkt_len;
skb687drivers/net/atp.cskb->dev = dev;
skb690drivers/net/atp.cread_block(ioaddr, pkt_len, skb->data, dev->if_port);
skb693drivers/net/atp.cunsigned char *data = skb->data;
skb701drivers/net/atp.cnetif_rx(skb);
skb703drivers/net/atp.cskb->lock = 0;
skb704drivers/net/atp.cif (dev_rint((unsigned char*)skb, pkt_len, IN_SKBUFF, dev) != 0) {
skb705drivers/net/atp.ckfree_s(skb, sksize);
skb226drivers/net/d_link.cstatic int  d_link_start_xmit(struct sk_buff *skb, struct device *dev);
skb384drivers/net/d_link.cd_link_start_xmit(struct sk_buff *skb, struct device *dev)
skb389drivers/net/d_link.cunsigned char  *buffer = skb->data;
skb397drivers/net/d_link.cif (skb == NULL) {
skb403drivers/net/d_link.cif (!skb->arp)
skb404drivers/net/d_link.cif(dev->rebuild_header(skb->data, dev)) {
skb405drivers/net/d_link.cskb->dev = dev;
skb406drivers/net/d_link.carp_queue (skb);
skb409drivers/net/d_link.cskb->arp = 1;
skb428drivers/net/d_link.cPRINTK(("d_link_start_xmit:len=%d, page %d/%d\n", skb->len, tx_fifo_in, free_tx_pages));
skb430drivers/net/d_link.cif ((len = skb->len) < RUNT)
skb457drivers/net/d_link.cif (skb->free)
skb458drivers/net/d_link.ckfree_skb (skb, FREE_WRITE);
skb558drivers/net/d_link.cstruct sk_buff  *skb;
skb581drivers/net/d_link.cskb = alloc_skb(sksize, GFP_ATOMIC);
skb583drivers/net/d_link.cif (skb == NULL) {
skb590drivers/net/d_link.cskb->lock = 0;
skb591drivers/net/d_link.cskb->mem_len = sksize;
skb592drivers/net/d_link.cskb->mem_addr = skb;
skb594drivers/net/d_link.cbuffer = skb->data;
skb603drivers/net/d_link.cif (dev_rint((unsigned char *)skb, size, IN_SKBUFF, dev))
skb289drivers/net/eexpress.cstatic int  eexp_send_packet(struct sk_buff *skb, struct device *dev);
skb472drivers/net/eexpress.ceexp_send_packet(struct sk_buff *skb, struct device *dev)
skb507drivers/net/eexpress.cif (skb == NULL) {
skb514drivers/net/eexpress.cif (!skb->arp  &&  dev->rebuild_header(skb->data, dev)) {
skb515drivers/net/eexpress.cskb->dev = dev;
skb516drivers/net/eexpress.carp_queue (skb);
skb519drivers/net/eexpress.cskb->arp=1;
skb525drivers/net/eexpress.cshort length = ETH_ZLEN < skb->len ? skb->len : ETH_ZLEN;
skb526drivers/net/eexpress.cunsigned char *buf = skb->data;
skb536drivers/net/eexpress.cif (skb->free)
skb537drivers/net/eexpress.ckfree_skb (skb, FREE_WRITE);
skb946drivers/net/eexpress.cstruct sk_buff *skb;
skb950drivers/net/eexpress.cskb = alloc_skb(sksize, GFP_ATOMIC);
skb951drivers/net/eexpress.cif (skb == NULL) {
skb956drivers/net/eexpress.cskb->mem_len = sksize;
skb957drivers/net/eexpress.cskb->mem_addr = skb;
skb958drivers/net/eexpress.cskb->len = pkt_len;
skb959drivers/net/eexpress.cskb->dev = dev;
skb963drivers/net/eexpress.cinsw(ioaddr, skb->data, (pkt_len + 1) >> 1);
skb966drivers/net/eexpress.cnetif_rx(skb);
skb968drivers/net/eexpress.cskb->lock = 0;
skb969drivers/net/eexpress.cif (dev_rint((unsigned char*)skb, pkt_len, IN_SKBUFF, dev) != 0) {
skb970drivers/net/eexpress.ckfree_s(skb, sksize);
skb211drivers/net/lance.cstatic int lance_start_xmit(struct sk_buff *skb, struct device *dev);
skb468drivers/net/lance.clance_start_xmit(struct sk_buff *skb, struct device *dev)
skb509drivers/net/lance.cif (skb == NULL) {
skb515drivers/net/lance.cif (!skb->arp  &&  dev->rebuild_header(skb->data, dev)) {
skb516drivers/net/lance.cskb->dev = dev;
skb517drivers/net/lance.carp_queue (skb);
skb520drivers/net/lance.cskb->arp=1;
skb522drivers/net/lance.cif (skb->len <= 0)
skb548drivers/net/lance.c-(ETH_ZLEN < skb->len ? skb->len : ETH_ZLEN);
skb550drivers/net/lance.clp->tx_ring[entry].length = -skb->len;
skb556drivers/net/lance.cif ((int)(skb->data) + skb->len > 0x01000000) {
skb559drivers/net/lance.cdev->name, (int)skb->data);
skb560drivers/net/lance.cmemcpy(&lp->tx_bounce_buffs[entry], skb->data, skb->len);
skb563drivers/net/lance.cif (skb->free)
skb564drivers/net/lance.ckfree_skb (skb, FREE_WRITE);
skb568drivers/net/lance.cif(skb->free==0)
skb569drivers/net/lance.cskb_kept_by_device(skb);
skb570drivers/net/lance.clp->tx_ring[entry].base = (int)skb->data | 0x83000000;
skb652drivers/net/lance.cstruct sk_buff *skb = ((struct sk_buff *)databuff) - 1;
skb653drivers/net/lance.cif (skb->free)
skb654drivers/net/lance.ckfree_skb(skb, FREE_WRITE);
skb656drivers/net/lance.cskb_device_release(skb,FREE_WRITE);
skb717drivers/net/lance.cstruct sk_buff *skb;
skb719drivers/net/lance.cskb = alloc_skb(sksize, GFP_ATOMIC);
skb720drivers/net/lance.cif (skb == NULL) {
skb725drivers/net/lance.cskb->mem_len = sksize;
skb726drivers/net/lance.cskb->mem_addr = skb;
skb727drivers/net/lance.cskb->len = pkt_len;
skb728drivers/net/lance.cskb->dev = dev;
skb729drivers/net/lance.cmemcpy(skb->data,
skb733drivers/net/lance.cnetif_rx(skb);
skb735drivers/net/lance.cskb->lock = 0;
skb736drivers/net/lance.cif (dev_rint((unsigned char*)skb, pkt_len, IN_SKBUFF, dev) != 0) {
skb737drivers/net/lance.ckfree_skbmem(skb, sksize);
skb139drivers/net/plip.cstatic int plip_tx_packet(struct sk_buff *skb, struct device *dev);
skb264drivers/net/plip.cplip_tx_packet(struct sk_buff *skb, struct device *dev)
skb281drivers/net/plip.cif (skb == NULL) {
skb288drivers/net/plip.cif (!skb->arp  &&  dev->rebuild_header(skb->data, dev)) {
skb289drivers/net/plip.cskb->dev = dev;
skb290drivers/net/plip.carp_queue (skb);
skb293drivers/net/plip.cskb->arp=1;
skb296drivers/net/plip.cret_val = plip_send_packet(dev, skb->data, skb->len);
skb297drivers/net/plip.cif (skb->free)
skb298drivers/net/plip.ckfree_skb (skb, FREE_WRITE);
skb424drivers/net/plip.cstruct sk_buff *skb;
skb474drivers/net/plip.cskb = alloc_skb(sksize, GFP_ATOMIC);
skb475drivers/net/plip.cif (skb == NULL) {
skb480drivers/net/plip.cskb->lock = 0;
skb481drivers/net/plip.cskb->mem_len = sksize;
skb482drivers/net/plip.cskb->mem_addr = skb;
skb487drivers/net/plip.cunsigned char *buf = skb->data;
skb504drivers/net/plip.c} else if(dev_rint((unsigned char *)skb, length, IN_SKBUFF, dev)) {
skb109drivers/net/skeleton.cstatic int  net_send_packet(struct sk_buff *skb, struct device *dev);
skb290drivers/net/skeleton.cnet_send_packet(struct sk_buff *skb, struct device *dev)
skb312drivers/net/skeleton.cif (skb == NULL) {
skb319drivers/net/skeleton.cif (!skb->arp  &&  dev->rebuild_header(skb->data, dev)) {
skb320drivers/net/skeleton.cskb->dev = dev;
skb321drivers/net/skeleton.carp_queue (skb);
skb324drivers/net/skeleton.cskb->arp=1;
skb331drivers/net/skeleton.cshort length = ETH_ZLEN < skb->len ? skb->len : ETH_ZLEN;
skb332drivers/net/skeleton.cunsigned char *buf = skb->data;
skb337drivers/net/skeleton.cif (skb->free)
skb338drivers/net/skeleton.ckfree_skb (skb, FREE_WRITE);
skb410drivers/net/skeleton.cstruct sk_buff *skb;
skb412drivers/net/skeleton.cskb = alloc_skb(sksize, GFP_ATOMIC);
skb413drivers/net/skeleton.cif (skb == NULL) {
skb418drivers/net/skeleton.cskb->mem_len = sksize;
skb419drivers/net/skeleton.cskb->mem_addr = skb;
skb420drivers/net/skeleton.cskb->len = pkt_len;
skb421drivers/net/skeleton.cskb->dev = dev;
skb424drivers/net/skeleton.cmemcpy(skb->data, (void*)dev->rmem_start,
skb427drivers/net/skeleton.cinsw(ioaddr, skb->data, (pkt_len + 1) >> 1);
skb430drivers/net/skeleton.cnetif_rx(skb);
skb432drivers/net/skeleton.cskb->lock = 0;
skb433drivers/net/skeleton.cif (dev_rint((unsigned char*)skb, pkt_len, IN_SKBUFF, dev) != 0) {
skb434drivers/net/skeleton.ckfree_s(skb, sksize);
skb521drivers/net/slip.csl_xmit(struct sk_buff *skb, struct device *dev)
skb530drivers/net/slip.cdev->name, skb, sl->sending));
skb544drivers/net/slip.cif (skb != NULL) {
skb548drivers/net/slip.cif(!skb->arp && dev->rebuild_header(skb->data,dev))
skb550drivers/net/slip.cskb->dev=dev;
skb551drivers/net/slip.carp_queue(skb);
skb554drivers/net/slip.cskb->arp=1;
skb559drivers/net/slip.csl_encaps(sl, skb->data, skb->len);
skb560drivers/net/slip.cif (skb->free) kfree_skb(skb, FREE_WRITE);
skb568drivers/net/slip.csl_type_trans (struct sk_buff *skb, struct device *dev)
skb596drivers/net/slip.csl_add_arp(unsigned long addr, struct sk_buff *skb, struct device *dev)
skb602drivers/net/slip.carp_add(addr,((char *) skb->data)+8,dev);
skb203net/inet/arp.cstruct sk_buff *skb;
skb210net/inet/arp.cwhile((skb=skb_dequeue(&work_q))!=NULL)
skb212net/inet/arp.cIS_SKB(skb);
skb213net/inet/arp.cskb->magic = 0;
skb214net/inet/arp.cskb->next = NULL;
skb215net/inet/arp.cskb->prev = NULL;
skb219net/inet/arp.cskb->tries--;
skb220net/inet/arp.cif (skb->tries == 0) {
skb230net/inet/arp.cskb->sk = NULL;
skb231net/inet/arp.cif(skb->free)
skb232net/inet/arp.ckfree_skb(skb, FREE_WRITE);
skb241net/inet/arp.cif (skb->arp || !skb->dev->rebuild_header(skb->data, skb->dev)) {
skb242net/inet/arp.cskb->arp  = 1;
skb243net/inet/arp.cskb->dev->queue_xmit(skb, skb->dev, 0);
skb246net/inet/arp.cskb->magic = ARP_QUEUE_MAGIC;      
skb247net/inet/arp.cskb_queue_head(&arp_q,skb);
skb260net/inet/arp.cstatic int arp_response(struct sk_buff *skb,struct arphdr *arp1, struct device *dev,  int addrtype)
skb279net/inet/arp.ckfree_skb(skb,FREE_READ);
skb284net/inet/arp.cskb->h.raw=skb->data;
skb285net/inet/arp.cskb->len+=dev->hard_header_len;  /* Grow the packet back to its original form */
skb289net/inet/arp.cif(len>skb->len)
skb292net/inet/arp.ckfree_skb(skb,FREE_READ);
skb296net/inet/arp.cskb->len      = len;
skb298net/inet/arp.chlen = dev->hard_header(skb->data, dev, ETH_P_ARP, src, dst, skb->len);
skb302net/inet/arp.ckfree_skb(skb, FREE_WRITE);
skb311net/inet/arp.carp2 = (struct arphdr *) (skb->data + hlen);
skb329net/inet/arp.cskb->free = 1;
skb330net/inet/arp.cskb->arp = 1;
skb331net/inet/arp.cskb->sk = NULL;
skb332net/inet/arp.cskb->next = NULL;
skb338net/inet/arp.cdev->queue_xmit(skb, dev, 0);
skb495net/inet/arp.carp_rcv(struct sk_buff *skb, struct device *dev, struct packet_type *pt)
skb505net/inet/arp.carp = skb->h.arp;
skb512net/inet/arp.ckfree_skb(skb, FREE_READ);
skb521net/inet/arp.ckfree_skb(skb, FREE_READ);
skb542net/inet/arp.ckfree_skb(skb, FREE_READ);
skb547net/inet/arp.ckfree_skb(skb, FREE_READ);
skb565net/inet/arp.ckfree_skb(skb, FREE_READ);
skb575net/inet/arp.ckfree_skb(skb, FREE_READ);
skb582net/inet/arp.ckfree_skb(skb, FREE_READ);
skb590net/inet/arp.cret = arp_response(skb,arp, dev, addr_hint);
skb599net/inet/arp.cstruct sk_buff *skb;
skb608net/inet/arp.cskb = alloc_skb(sizeof(struct sk_buff) +
skb612net/inet/arp.cif (skb == NULL) {
skb618net/inet/arp.cskb->sk = NULL;
skb619net/inet/arp.cskb->len = sizeof(struct arphdr) +
skb621net/inet/arp.cskb->arp = 1;
skb622net/inet/arp.cskb->dev = dev;
skb623net/inet/arp.cskb->free = 1;
skb624net/inet/arp.cskb->next = NULL;
skb625net/inet/arp.ctmp = dev->hard_header(skb->data, dev, ETH_P_ARP, 0, saddr, skb->len);
skb627net/inet/arp.ckfree_skb(skb,FREE_WRITE);
skb630net/inet/arp.carp = (struct arphdr *) (skb->data + tmp);
skb652net/inet/arp.cdev->queue_xmit(skb, dev, 0);
skb752net/inet/arp.carp_queue(struct sk_buff *skb)
skb755net/inet/arp.cskb->tries = ARP_MAX_TRIES;
skb757net/inet/arp.cif (skb->next != NULL) {
skb759net/inet/arp.cprintk("ARP: arp_queue skb already on queue magic=%X.\n", skb->magic);
skb762net/inet/arp.cskb_queue_tail(&arp_q,skb);
skb763net/inet/arp.cskb->magic = ARP_QUEUE_MAGIC;
skb52net/inet/arp.hextern int  arp_rcv(struct sk_buff *skb, struct device *dev,
skb59net/inet/arp.hextern void  arp_queue(struct sk_buff *skb);
skb51net/inet/datagram.cstruct sk_buff *skb;
skb121net/inet/datagram.cskb=skb_dequeue(&sk->rqueue);
skb122net/inet/datagram.cif(skb!=NULL)
skb123net/inet/datagram.cskb->users++;
skb130net/inet/datagram.cskb=skb_peek(&sk->rqueue);
skb131net/inet/datagram.cif(skb!=NULL)
skb132net/inet/datagram.cskb->users++;
skb134net/inet/datagram.cif(skb==NULL)  /* shouldn't happen but .. */
skb137net/inet/datagram.creturn skb;
skb140net/inet/datagram.cvoid skb_free_datagram(struct sk_buff *skb)
skb146net/inet/datagram.cskb->users--;
skb147net/inet/datagram.cif(skb->users>0)
skb153net/inet/datagram.cif(skb->list == NULL)  /* Been dequeued by someone - ie its read */
skb154net/inet/datagram.ckfree_skb(skb,FREE_READ);
skb158net/inet/datagram.cvoid skb_copy_datagram(struct sk_buff *skb, int offset, char *to, int size)
skb162net/inet/datagram.cmemcpy_tofs(to,skb->h.raw+offset,size);
skb444net/inet/dev.cstruct sk_buff *skb;
skb445net/inet/dev.cwhile((skb=skb_dequeue(&dev->buffs[ct]))!=NULL)
skb446net/inet/dev.cif(skb->free)
skb447net/inet/dev.ckfree_skb(skb,FREE_WRITE);
skb458net/inet/dev.cdev_queue_xmit(struct sk_buff *skb, struct device *dev, int pri)
skb465net/inet/dev.cskb, dev, pri));
skb472net/inet/dev.cIS_SKB(skb);
skb474net/inet/dev.cskb->dev = dev;
skb475net/inet/dev.cif (skb->next != NULL) {
skb491net/inet/dev.cif (dev->hard_start_xmit(skb, dev) == 0) {
skb501net/inet/dev.cskb->magic = DEV_QUEUE_MAGIC;
skb503net/inet/dev.cskb_queue_head(&dev->buffs[pri],skb);
skb505net/inet/dev.cskb_queue_tail(&dev->buffs[pri],skb);
skb506net/inet/dev.cskb->magic = DEV_QUEUE_MAGIC;
skb515net/inet/dev.cnetif_rx(struct sk_buff *skb)
skb518net/inet/dev.cskb->sk = NULL;
skb519net/inet/dev.cskb->free = 1;
skb522net/inet/dev.cIS_SKB(skb);
skb523net/inet/dev.cskb_queue_tail(&backlog,skb);
skb546net/inet/dev.cstruct sk_buff *skb = NULL;
skb553net/inet/dev.cskb = (struct sk_buff *) buff;
skb562net/inet/dev.cskb = alloc_skb(sizeof(*skb) + len, GFP_ATOMIC);
skb563net/inet/dev.cif (skb == NULL) {
skb569net/inet/dev.cskb->mem_len = sizeof(*skb) + len;
skb570net/inet/dev.cskb->mem_addr = (struct sk_buff *) skb;
skb573net/inet/dev.cto = skb->data;
skb588net/inet/dev.cskb->len = len;
skb589net/inet/dev.cskb->dev = dev;
skb590net/inet/dev.cskb->free = 1;
skb592net/inet/dev.cnetif_rx(skb);
skb626net/inet/dev.cstruct sk_buff *skb;
skb640net/inet/dev.cwhile((skb=skb_dequeue(&backlog))!=NULL)
skb651net/inet/dev.cskb->h.raw = skb->data + skb->dev->hard_header_len;
skb652net/inet/dev.cskb->len -= skb->dev->hard_header_len;
skb663net/inet/dev.ctype = skb->dev->type_trans(skb, skb->dev);
skb678net/inet/dev.cskb2 = alloc_skb(skb->mem_len, GFP_ATOMIC);
skb681net/inet/dev.cmemcpy(skb2, (const void *) skb, skb->mem_len);
skb685net/inet/dev.c(unsigned long) skb->h.raw -
skb686net/inet/dev.c(unsigned long) skb
skb690net/inet/dev.cskb2 = skb;
skb700net/inet/dev.cptype->func(skb2, skb->dev, ptype);
skb711net/inet/dev.cskb->sk = NULL;
skb712net/inet/dev.ckfree_skb(skb, FREE_WRITE);
skb733net/inet/dev.cstruct sk_buff *skb;
skb736net/inet/dev.cwhile((skb=skb_dequeue(&dev->buffs[i]))!=NULL)
skb738net/inet/dev.cskb->magic = 0;
skb739net/inet/dev.cskb->next = NULL;
skb740net/inet/dev.cskb->prev = NULL;
skb741net/inet/dev.cdev->queue_xmit(skb,dev,-i - 1);
skb119net/inet/dev.hint        (*hard_start_xmit) (struct sk_buff *skb,
skb128net/inet/dev.hstruct sk_buff *skb,
skb130net/inet/dev.hvoid        (*queue_xmit)(struct sk_buff *skb,
skb133net/inet/dev.hunsigned short    (*type_trans) (struct sk_buff *skb,
skb175net/inet/dev.hextern void    dev_queue_xmit(struct sk_buff *skb, struct device *dev,
skb178net/inet/dev.hextern void    netif_rx(struct sk_buff *skb);
skb167net/inet/eth.ceth_add_arp(unsigned long addr, struct sk_buff *skb, struct device *dev)
skb171net/inet/eth.ceth = (struct ethhdr *) skb->data;
skb178net/inet/eth.ceth_type_trans(struct sk_buff *skb, struct device *dev)
skb182net/inet/eth.ceth = (struct ethhdr *) skb->data;
skb31net/inet/eth.hextern void    eth_add_arp(unsigned long addr, struct sk_buff *skb,
skb33net/inet/eth.hextern unsigned short  eth_type_trans(struct sk_buff *skb, struct device *dev);
skb83net/inet/icmp.cstruct sk_buff *skb;
skb97net/inet/icmp.cskb = (struct sk_buff *) alloc_skb(len, GFP_ATOMIC);
skb98net/inet/icmp.cif (skb == NULL) 
skb101net/inet/icmp.cskb->sk = NULL;
skb102net/inet/icmp.cskb->mem_addr = skb;
skb103net/inet/icmp.cskb->mem_len = len;
skb110net/inet/icmp.coffset = ip_build_header(skb, dev->pa_addr, iph->saddr,
skb113net/inet/icmp.cskb->sk = NULL;
skb114net/inet/icmp.ckfree_skb(skb, FREE_READ);
skb119net/inet/icmp.cskb->len = offset + sizeof(struct icmphdr) + sizeof(struct iphdr) + 8;
skb120net/inet/icmp.cicmph = (struct icmphdr *) (skb->data + offset);
skb134net/inet/icmp.cip_queue_xmit(NULL, dev, skb, 1);
skb140net/inet/icmp.cicmp_unreach(struct icmphdr *icmph, struct sk_buff *skb)
skb197net/inet/icmp.cskb->sk = NULL;
skb198net/inet/icmp.ckfree_skb(skb, FREE_READ);
skb204net/inet/icmp.cicmp_redirect(struct icmphdr *icmph, struct sk_buff *skb, struct device *dev)
skb229net/inet/icmp.cskb->sk = NULL;
skb230net/inet/icmp.ckfree_skb(skb, FREE_READ);
skb236net/inet/icmp.cicmp_echo(struct icmphdr *icmph, struct sk_buff *skb, struct device *dev,
skb247net/inet/icmp.cskb->sk = NULL;
skb248net/inet/icmp.ckfree_skb(skb, FREE_READ);
skb258net/inet/icmp.cIPPROTO_ICMP, opt, len, skb->ip_hdr->tos,255);
skb262net/inet/icmp.cskb->sk = NULL;
skb263net/inet/icmp.ckfree_skb(skb, FREE_READ);
skb281net/inet/icmp.cskb->sk = NULL;
skb282net/inet/icmp.ckfree_skb(skb, FREE_READ);
skb288net/inet/icmp.cicmp_info(struct icmphdr *icmph, struct sk_buff *skb, struct device *dev,
skb293net/inet/icmp.cskb->sk = NULL;
skb294net/inet/icmp.ckfree_skb(skb, FREE_READ);
skb300net/inet/icmp.cicmp_address(struct icmphdr *icmph, struct sk_buff *skb, struct device *dev,
skb311net/inet/icmp.cskb->sk = NULL;
skb312net/inet/icmp.ckfree_skb(skb, FREE_READ);
skb322net/inet/icmp.cIPPROTO_ICMP, opt, len, skb->ip_hdr->tos,255);
skb326net/inet/icmp.cskb->sk = NULL;
skb327net/inet/icmp.ckfree_skb(skb, FREE_READ);
skb348net/inet/icmp.cskb->sk = NULL;
skb349net/inet/icmp.ckfree_skb(skb, FREE_READ);
skb177net/inet/ip.cip_send(struct sk_buff *skb, unsigned long daddr, int len, struct device *dev,
skb183net/inet/ip.cptr = skb->data;
skb185net/inet/ip.cskb->arp = 1;
skb191net/inet/ip.cskb->arp = 0;
skb193net/inet/ip.cskb->dev = dev;
skb205net/inet/ip.cip_build_header(struct sk_buff *skb, unsigned long saddr, unsigned long daddr,
skb221net/inet/ip.cskb, saddr, daddr, *dev, type, opt, len));
skb223net/inet/ip.cbuff = skb->data;
skb247net/inet/ip.ctmp = ip_send(skb, raddr, len, *dev, saddr);
skb251net/inet/ip.cskb->dev = *dev;
skb252net/inet/ip.cskb->saddr = saddr;
skb253net/inet/ip.cif (skb->sk) skb->sk->saddr = saddr;
skb520net/inet/ip.cstatic struct ipfrag *ip_frag_create(int offset, int end, struct sk_buff *skb, unsigned char *ptr)
skb536net/inet/ip.cfp->skb = skb;
skb605net/inet/ip.cIS_SKB(fp->skb);
skb606net/inet/ip.ckfree_skb(fp->skb,FREE_READ);
skb641net/inet/ip.cicmp_send(qp->fragments->skb,ICMP_TIME_EXCEEDED,
skb656net/inet/ip.cstatic struct ipq *ip_create(struct sk_buff *skb, struct iphdr *iph, struct device *dev)
skb671net/inet/ip.cmaclen = ((unsigned long) iph) - ((unsigned long) skb->data);
skb692net/inet/ip.cmemcpy(qp->mac, skb->data, maclen);
skb748net/inet/ip.cstruct sk_buff *skb;
skb756net/inet/ip.cif ((skb = alloc_skb(len,GFP_ATOMIC)) == NULL) 
skb764net/inet/ip.cskb->len = (len - qp->maclen);
skb765net/inet/ip.cskb->h.raw = skb->data;
skb766net/inet/ip.cskb->free = 1;
skb767net/inet/ip.cskb->lock = 1;
skb770net/inet/ip.cptr = (unsigned char *) skb->h.raw;
skb777net/inet/ip.cskb->h.raw += qp->maclen;
skb786net/inet/ip.cif(count+fp->len>skb->len)
skb789net/inet/ip.ckfree_skb(skb,FREE_WRITE);
skb802net/inet/ip.ciph = skb->h.iph;
skb805net/inet/ip.cskb->ip_hdr = iph;
skb806net/inet/ip.creturn(skb);
skb811net/inet/ip.cstatic struct sk_buff *ip_defrag(struct iphdr *iph, struct sk_buff *skb, struct device *dev)
skb832net/inet/ip.creturn(skb);
skb851net/inet/ip.cif ((qp = ip_create(skb, iph, dev)) == NULL) 
skb860net/inet/ip.cptr = skb->data + dev->hard_header_len + ihl;
skb928net/inet/ip.ctfp = ip_frag_create(offset, end, skb, ptr);
skb962net/inet/ip.cvoid ip_fragment(struct sock *sk, struct sk_buff *skb, struct device *dev, int is_frag)
skb972net/inet/ip.craw = skb->data;
skb1000net/inet/ip.cicmp_send(skb,ICMP_DEST_UNREACH, ICMP_FRAG_NEEDED, dev); 
skb1028net/inet/ip.cskb2->arp = skb->arp;
skb1029net/inet/ip.cskb2->free = skb->free;
skb1067net/inet/ip.cip_forward(struct sk_buff *skb, struct device *dev, int is_frag)
skb1083net/inet/ip.cif(memcmp((char *)&skb[1],dev->dev_addr,dev->addr_len))
skb1092net/inet/ip.ciph = skb->h.iph;
skb1100net/inet/ip.cicmp_send(skb, ICMP_TIME_EXCEEDED, ICMP_EXC_TTL, dev);
skb1116net/inet/ip.cicmp_send(skb, ICMP_DEST_UNREACH, ICMP_NET_UNREACH, dev);
skb1135net/inet/ip.cicmp_send(skb, ICMP_DEST_UNREACH, ICMP_HOST_UNREACH, dev);
skb1151net/inet/ip.cin_ntoa(raddr), dev2->name, skb->len));
skb1155net/inet/ip.cdev2->hard_header_len + skb->len, GFP_ATOMIC);
skb1163net/inet/ip.cskb2->len = skb->len + dev2->hard_header_len;
skb1170net/inet/ip.cmemcpy(ptr + dev2->hard_header_len, skb->h.raw, skb->len);
skb1173net/inet/ip.c(void) ip_send(skb2, raddr, skb->len, dev2, dev2->pa_addr);
skb1190net/inet/ip.cip_rcv(struct sk_buff *skb, struct device *dev, struct packet_type *pt)
skb1192net/inet/ip.cstruct iphdr *iph = skb->h.iph;
skb1204net/inet/ip.cskb->ip_hdr = iph;    /* Fragments can cause ICMP errors too! */
skb1206net/inet/ip.cif (skb->len<sizeof(struct iphdr) || iph->ihl<5 || iph->version != 4 || ip_fast_csum((unsigned char *)iph, iph->ihl) !=0) {
skb1210net/inet/ip.cskb->sk = NULL;
skb1211net/inet/ip.ckfree_skb(skb, FREE_WRITE);
skb1231net/inet/ip.cip_forward(skb, dev, is_frag);
skb1236net/inet/ip.cskb->sk = NULL;
skb1237net/inet/ip.ckfree_skb(skb, FREE_WRITE);
skb1248net/inet/ip.cskb=ip_defrag(iph,skb,dev);
skb1249net/inet/ip.cif(skb==NULL)
skb1253net/inet/ip.ciph=skb->h.iph;
skb1258net/inet/ip.cicmp_send(skb, ICMP_DEST_UNREACH, ICMP_PROT_UNREACH, dev);
skb1259net/inet/ip.cskb->sk = NULL;
skb1260net/inet/ip.ckfree_skb(skb, FREE_WRITE);
skb1271net/inet/ip.cskb->sk=NULL;
skb1272net/inet/ip.ckfree_skb(skb,FREE_WRITE);
skb1278net/inet/ip.cskb->ip_hdr = iph;
skb1279net/inet/ip.cskb->h.raw += iph->ihl*4;
skb1297net/inet/ip.cskb2 = alloc_skb(skb->mem_len, GFP_ATOMIC);
skb1300net/inet/ip.cmemcpy(skb2, skb, skb->mem_len);
skb1304net/inet/ip.c(unsigned long) skb->ip_hdr -
skb1305net/inet/ip.c(unsigned long)skb);
skb1308net/inet/ip.c(unsigned long) skb->h.raw -
skb1309net/inet/ip.c(unsigned long)skb);
skb1312net/inet/ip.cskb2 = skb;
skb1335net/inet/ip.cicmp_send(skb, ICMP_DEST_UNREACH, ICMP_PROT_UNREACH, dev);
skb1336net/inet/ip.cskb->sk = NULL;
skb1337net/inet/ip.ckfree_skb(skb, FREE_WRITE);
skb1353net/inet/ip.cstruct sk_buff *skb, int free)
skb1363net/inet/ip.cIS_SKB(skb);
skb1364net/inet/ip.cskb->free = free;
skb1365net/inet/ip.cskb->dev = dev;
skb1366net/inet/ip.cskb->when = jiffies;
skb1369net/inet/ip.cptr = skb->data;
skb1372net/inet/ip.ciph->tot_len = ntohs(skb->len-dev->hard_header_len);
skb1374net/inet/ip.cif(skb->len > dev->mtu)
skb1377net/inet/ip.cip_fragment(sk,skb,dev,0);
skb1378net/inet/ip.cIS_SKB(skb);
skb1379net/inet/ip.ckfree_skb(skb,FREE_WRITE);
skb1385net/inet/ip.cskb->next = NULL;
skb1388net/inet/ip.cskb->magic = 1;
skb1390net/inet/ip.cskb->link3 = NULL;
skb1394net/inet/ip.csk->send_tail = skb;
skb1395net/inet/ip.csk->send_head = skb;
skb1402net/inet/ip.csk->send_tail->link3 = skb;
skb1403net/inet/ip.csk->send_tail = skb;
skb1409net/inet/ip.cskb->sk = sk;
skb1415net/inet/ip.cdev->queue_xmit(skb, dev, sk->priority);
skb1418net/inet/ip.cdev->queue_xmit(skb, dev, SOPRI_NORMAL);
skb1421net/inet/ip.cif (free) kfree_skb(skb, FREE_WRITE);
skb1429net/inet/ip.cstruct sk_buff * skb;
skb1435net/inet/ip.cskb = sk->send_head;
skb1437net/inet/ip.cwhile (skb != NULL) {
skb1438net/inet/ip.cdev = skb->dev;
skb1446net/inet/ip.cIS_SKB(skb);
skb1456net/inet/ip.cif (!skb->arp) {
skb1457net/inet/ip.cif (dev->rebuild_header(skb->data, dev)) {
skb1460net/inet/ip.cskb = (struct sk_buff *)skb->link3;
skb1464net/inet/ip.cskb->arp = 1;
skb1466net/inet/ip.cskb->when = jiffies;
skb1470net/inet/ip.cif (sk && !skb_device_locked(skb))
skb1471net/inet/ip.cdev->queue_xmit(skb, dev, sk->priority);
skb1481net/inet/ip.cskb = (struct sk_buff *)skb->link3;
skb41net/inet/ip.hstruct sk_buff *skb;      /* complete received fragment    */
skb68net/inet/ip.hextern int    ip_build_header(struct sk_buff *skb,
skb75net/inet/ip.hextern int    ip_rcv(struct sk_buff *skb, struct device *dev,
skb78net/inet/ip.hstruct device *dev, struct sk_buff *skb,
skb47net/inet/loopback.cloopback_xmit(struct sk_buff *skb, struct device *dev)
skb52net/inet/loopback.cDPRINTF((DBG_LOOPB, "loopback_xmit(dev=%X, skb=%X)\n", dev, skb));
skb53net/inet/loopback.cif (skb == NULL || dev == NULL) return(0);
skb64net/inet/loopback.cdone = dev_rint(skb->data, skb->len, 0, dev);
skb65net/inet/loopback.cif (skb->free) kfree_skb(skb, FREE_WRITE);
skb59net/inet/packet.cpacket_rcv(struct sk_buff *skb, struct device *dev,  struct packet_type *pt)
skb64net/inet/packet.cskb->dev = dev;
skb65net/inet/packet.cskb->len += dev->hard_header_len;
skb67net/inet/packet.cskb->sk = sk;
skb70net/inet/packet.cif (sk->rmem_alloc + skb->mem_len >= sk->rcvbuf) {
skb71net/inet/packet.cskb->sk = NULL;
skb72net/inet/packet.ckfree_skb(skb, FREE_READ);
skb75net/inet/packet.csk->rmem_alloc += skb->mem_len;
skb76net/inet/packet.cskb_queue_tail(&sk->rqueue,skb);
skb89net/inet/packet.cstruct sk_buff *skb;
skb122net/inet/packet.cskb = sk->prot->wmalloc(sk, len+sizeof(*skb), 0, GFP_KERNEL);
skb125net/inet/packet.cif (skb == NULL) {
skb130net/inet/packet.cskb->mem_addr = skb;
skb131net/inet/packet.cskb->mem_len = len + sizeof(*skb);
skb132net/inet/packet.cskb->sk = sk;
skb133net/inet/packet.cskb->free = 1;
skb134net/inet/packet.cmemcpy_fromfs(skb->data, from, len);
skb135net/inet/packet.cskb->len = len;
skb136net/inet/packet.cskb->next = NULL;
skb137net/inet/packet.cskb->arp = 1;
skb138net/inet/packet.cif (dev->flags & IFF_UP) dev->queue_xmit(skb, dev, sk->priority);
skb139net/inet/packet.celse kfree_skb(skb, FREE_WRITE);
skb194net/inet/packet.cstruct sk_buff *skb;
skb213net/inet/packet.cskb=skb_recv_datagram(sk,flags,noblock,&err);
skb214net/inet/packet.cif(skb==NULL)
skb216net/inet/packet.ccopied = min(len, skb->len);
skb218net/inet/packet.cmemcpy_tofs(to, skb->data, copied);  /* Don't use skb_copy_datagram here: We can't get frag chains */
skb224net/inet/packet.caddr.sa_family = skb->dev->type;
skb225net/inet/packet.cmemcpy(addr.sa_data,skb->dev->name, 14);
skb230net/inet/packet.cskb_free_datagram(skb);    /* Its either been used up, or its a peek_copy anyway */
skb31net/inet/protocol.hint      (*handler)(struct sk_buff *skb, struct device *dev,
skb35net/inet/protocol.hint      (*frag_handler)(struct sk_buff *skb, struct device *dev,
skb94net/inet/raw.craw_rcv(struct sk_buff *skb, struct device *dev, struct options *opt,
skb102net/inet/raw.cskb, dev, opt, daddr, len, saddr, redo, protocol));
skb104net/inet/raw.cif (skb == NULL) return(0);
skb106net/inet/raw.ckfree_skb(skb, FREE_READ);
skb111net/inet/raw.ckfree_skb(skb, FREE_READ);
skb116net/inet/raw.cskb->sk = sk;
skb117net/inet/raw.cskb->len = len + skb->ip_hdr->ihl*sizeof(long);
skb118net/inet/raw.cskb->h.raw = skb->ip_hdr;
skb119net/inet/raw.cskb->dev = dev;
skb120net/inet/raw.cskb->saddr = daddr;
skb121net/inet/raw.cskb->daddr = saddr;
skb124net/inet/raw.cif (sk->rmem_alloc + skb->mem_len >= sk->rcvbuf) {
skb125net/inet/raw.cskb->sk = NULL;
skb126net/inet/raw.ckfree_skb(skb, FREE_READ);
skb129net/inet/raw.csk->rmem_alloc += skb->mem_len;
skb130net/inet/raw.cskb_queue_tail(&sk->rqueue,skb);
skb131net/inet/raw.csk->data_ready(sk,skb->len);
skb143net/inet/raw.cstruct sk_buff *skb;
skb180net/inet/raw.cskb = NULL;
skb181net/inet/raw.cwhile (skb == NULL) {
skb190net/inet/raw.cskb = sk->prot->wmalloc(sk,
skb191net/inet/raw.clen+sizeof(*skb) + sk->prot->max_header,
skb193net/inet/raw.cif (skb == NULL) {
skb213net/inet/raw.cskb->mem_addr = skb;
skb214net/inet/raw.cskb->mem_len = len + sizeof(*skb) +sk->prot->max_header;
skb215net/inet/raw.cskb->sk = sk;
skb217net/inet/raw.cskb->free = 1; /* these two should be unecessary. */
skb218net/inet/raw.cskb->arp = 0;
skb220net/inet/raw.ctmp = sk->prot->build_header(skb, sk->saddr, 
skb222net/inet/raw.csk->protocol, sk->opt, skb->mem_len, sk->ip_tos,sk->ip_ttl);
skb225net/inet/raw.ckfree_skb(skb,FREE_WRITE);
skb231net/inet/raw.cmemcpy_fromfs(skb->data + tmp, from, len);
skb240net/inet/raw.cbuff = skb->data;
skb246net/inet/raw.cskb->len = tmp + len;
skb248net/inet/raw.cif(dev!=NULL && skb->len > 4095)
skb250net/inet/raw.ckfree_skb(skb, FREE_WRITE);
skb255net/inet/raw.csk->prot->queue_xmit(sk, dev, skb, 1);
skb321net/inet/raw.cstruct sk_buff *skb;
skb349net/inet/raw.cskb=skb_recv_datagram(sk,flags,noblock,&err);
skb350net/inet/raw.cif(skb==NULL)
skb353net/inet/raw.ccopied = min(len, skb->len);
skb355net/inet/raw.cskb_copy_datagram(skb, 0, to, copied);
skb362net/inet/raw.caddr.sin_addr.s_addr = skb->daddr;
skb366net/inet/raw.cskb_free_datagram(skb);
skb26net/inet/raw.hextern int  raw_rcv(struct sk_buff *skb, struct device *dev,
skb57net/inet/skbuff.cvoid skb_check(struct sk_buff *skb, int line, char *file)
skb59net/inet/skbuff.cif(skb->magic_debug_cookie==SK_FREED_SKB)
skb64net/inet/skbuff.cskb,skb->truesize,skb->mem_len,skb->magic,skb->list,skb->free);
skb66net/inet/skbuff.cif(skb->magic_debug_cookie!=SK_GOOD_SKB)
skb70net/inet/skbuff.cskb,skb->truesize,skb->mem_len,skb->magic,skb->list,skb->free);
skb72net/inet/skbuff.cif(skb->mem_len!=skb->truesize)
skb76net/inet/skbuff.cskb,skb->truesize,skb->mem_len,skb->magic,skb->list);
skb247net/inet/skbuff.cvoid skb_unlink(struct sk_buff *skb)
skb253net/inet/skbuff.cIS_SKB(skb);
skb255net/inet/skbuff.cif(skb->list)
skb257net/inet/skbuff.cskb->next->prev=skb->prev;
skb258net/inet/skbuff.cskb->prev->next=skb->next;
skb259net/inet/skbuff.cif(*skb->list==skb)
skb261net/inet/skbuff.cif(skb->next==skb)
skb262net/inet/skbuff.c*skb->list=NULL;
skb264net/inet/skbuff.c*skb->list=skb->next;
skb266net/inet/skbuff.cskb->next=0;
skb267net/inet/skbuff.cskb->prev=0;
skb268net/inet/skbuff.cskb->list=0;
skb281net/inet/skbuff.cstruct sk_buff *skb=skb_peek(list);
skb282net/inet/skbuff.cif(skb!=NULL)
skb286net/inet/skbuff.cIS_SKB(skb);
skb287net/inet/skbuff.cskb->list=list;
skb288net/inet/skbuff.cskb=skb->next;
skb290net/inet/skbuff.cwhile(skb!=*list);
skb377net/inet/skbuff.cvoid kfree_skb(struct sk_buff *skb, int rw)
skb379net/inet/skbuff.cif (skb == NULL) {
skb383net/inet/skbuff.cIS_SKB(skb);
skb384net/inet/skbuff.cif(skb->lock)
skb386net/inet/skbuff.cskb->free=1;  /* Free when unlocked */
skb390net/inet/skbuff.cif(skb->free == 2)
skb392net/inet/skbuff.cif(skb->list)
skb394net/inet/skbuff.cskb->magic = 0;
skb395net/inet/skbuff.cif (skb->sk)
skb397net/inet/skbuff.cif(skb->sk->prot!=NULL)
skb400net/inet/skbuff.cskb->sk->prot->rfree(skb->sk, skb->mem_addr, skb->mem_len);
skb402net/inet/skbuff.cskb->sk->prot->wfree(skb->sk, skb->mem_addr, skb->mem_len);
skb409net/inet/skbuff.cskb->sk->rmem_alloc-=skb->mem_len;
skb411net/inet/skbuff.cskb->sk->wmem_alloc-=skb->mem_len;
skb412net/inet/skbuff.cif(!skb->sk->dead)
skb413net/inet/skbuff.cwake_up_interruptible(skb->sk->sleep);
skb414net/inet/skbuff.ckfree_skbmem(skb->mem_addr,skb->mem_len);
skb418net/inet/skbuff.ckfree_skbmem(skb->mem_addr, skb->mem_len);
skb428net/inet/skbuff.cstruct sk_buff *skb=(struct sk_buff *)kmalloc(size,priority);
skb429net/inet/skbuff.cif(skb==NULL)
skb431net/inet/skbuff.cskb->free= 2;  /* Invalid so we pick up forgetful users */
skb432net/inet/skbuff.cskb->list= 0;  /* Not on a list */
skb433net/inet/skbuff.cskb->lock= 0;
skb434net/inet/skbuff.cskb->truesize=size;
skb435net/inet/skbuff.cskb->mem_len=size;
skb436net/inet/skbuff.cskb->mem_addr=skb;
skb437net/inet/skbuff.cskb->fraglist=NULL;
skb440net/inet/skbuff.cskb->magic_debug_cookie=SK_GOOD_SKB;
skb441net/inet/skbuff.cskb->users=0;
skb442net/inet/skbuff.creturn skb;
skb466net/inet/skbuff.cvoid skb_kept_by_device(struct sk_buff *skb)
skb468net/inet/skbuff.cskb->lock++;
skb471net/inet/skbuff.cvoid skb_device_release(struct sk_buff *skb, int mode)
skb477net/inet/skbuff.cif (!--skb->lock) {
skb478net/inet/skbuff.cif (skb->free==1)
skb479net/inet/skbuff.ckfree_skb(skb,mode);
skb484net/inet/skbuff.cint skb_device_locked(struct sk_buff *skb)
skb486net/inet/skbuff.cif(skb->lock)
skb90net/inet/skbuff.hextern void      kfree_skb(struct sk_buff *skb, int rw);
skb102net/inet/skbuff.hextern void      skb_kept_by_device(struct sk_buff *skb);
skb103net/inet/skbuff.hextern void      skb_device_release(struct sk_buff *skb, int mode);
skb104net/inet/skbuff.hextern int      skb_device_locked(struct sk_buff *skb);
skb105net/inet/skbuff.hextern void       skb_check(struct sk_buff *skb,int, char *);
skb106net/inet/skbuff.h#define IS_SKB(skb)  skb_check((skb),__LINE__,__FILE__)
skb111net/inet/skbuff.hextern void      skb_free_datagram(struct sk_buff *skb);
skb138net/inet/sock.cprint_skb(struct sk_buff *skb)
skb140net/inet/sock.cif (!skb) {
skb144net/inet/sock.cprintk("  prev = %p, next = %p\n", skb->prev, skb->next);
skb145net/inet/sock.cprintk("  sk = %p link3 = %p\n", skb->sk, skb->link3);
skb146net/inet/sock.cprintk("  mem_addr = %p, mem_len = %lu\n", skb->mem_addr, skb->mem_len);
skb147net/inet/sock.cprintk("  used = %d free = %d\n", skb->used,skb->free);
skb312net/inet/sock.cstruct sk_buff *skb;
skb327net/inet/sock.cwhile ((skb = tcp_dequeue_partial(sk)) != NULL) 
skb329net/inet/sock.cIS_SKB(skb);
skb330net/inet/sock.ckfree_skb(skb, FREE_WRITE);
skb334net/inet/sock.cfor(skb = sk->wfront; skb != NULL; ) 
skb338net/inet/sock.cskb2=(struct sk_buff *)skb->next;
skb339net/inet/sock.cif (skb->magic != TCP_WRITE_QUEUE_MAGIC) {
skb341net/inet/sock.cskb->magic);
skb344net/inet/sock.cIS_SKB(skb);
skb345net/inet/sock.ckfree_skb(skb, FREE_WRITE);
skb346net/inet/sock.cskb = skb2;
skb354net/inet/sock.cwhile((skb=skb_dequeue(&sk->rqueue))!=NULL)
skb360net/inet/sock.cif (skb->sk != NULL && skb->sk != sk) 
skb362net/inet/sock.cIS_SKB(skb);
skb363net/inet/sock.cskb->sk->dead = 1;
skb364net/inet/sock.cskb->sk->prot->close(skb->sk, 0);
skb366net/inet/sock.cIS_SKB(skb);
skb367net/inet/sock.ckfree_skb(skb, FREE_READ);
skb373net/inet/sock.cfor(skb = sk->send_head; skb != NULL; ) 
skb385net/inet/sock.cif (skb->next != NULL) 
skb387net/inet/sock.cIS_SKB(skb);
skb388net/inet/sock.cskb_unlink(skb);
skb390net/inet/sock.cskb->dev = NULL;
skb392net/inet/sock.cskb2 = (struct sk_buff *)skb->link3;
skb393net/inet/sock.ckfree_skb(skb, FREE_WRITE);
skb394net/inet/sock.cskb = skb2;
skb404net/inet/sock.cskb = (struct sk_buff *)sk->back_log;
skb409net/inet/sock.cskb2 = (struct sk_buff *)skb->next;
skb410net/inet/sock.ckfree_skb(skb, FREE_READ);
skb411net/inet/sock.cskb = skb2;
skb413net/inet/sock.cwhile(skb != sk->back_log);
skb1737net/inet/sock.cstruct sk_buff *skb;
skb1740net/inet/sock.cskb =(struct sk_buff *)sk->back_log;
skb1741net/inet/sock.cDPRINTF((DBG_INET, "release_sock: skb = %X:\n", skb));
skb1742net/inet/sock.cif (skb->next != skb) {
skb1743net/inet/sock.csk->back_log = skb->next;
skb1744net/inet/sock.cskb->prev->next = skb->next;
skb1745net/inet/sock.cskb->next->prev = skb->prev;
skb1751net/inet/sock.cif (sk->prot->rcv) sk->prot->rcv(skb, skb->dev, sk->opt,
skb1752net/inet/sock.cskb->saddr, skb->len, skb->daddr, 1,
skb197net/inet/sock.hint      (*build_header)(struct sk_buff *skb,
skb206net/inet/sock.hstruct device *dev, struct sk_buff *skb,
skb304net/inet/tcp.cstruct sk_buff *skb;
skb325net/inet/tcp.cskb =(struct sk_buff *)sk->rqueue;
skb339net/inet/tcp.cif (before(counted, skb->h.th->seq))   /* Found a hole so stops here */
skb341net/inet/tcp.csum = skb->len -(counted - skb->h.th->seq);  /* Length - header but start from where we are up to (avoid overlaps) */
skb342net/inet/tcp.cif (skb->h.th->syn) sum++;
skb343net/inet/tcp.cif (skb->h.th->urg) {
skb344net/inet/tcp.csum -= ntohs(skb->h.th->urg_ptr);  /* Dont count urg data */
skb348net/inet/tcp.cif (skb->h.th->syn) amount--;
skb351net/inet/tcp.cif (amount && skb->h.th->psh) break;
skb352net/inet/tcp.cskb =(struct sk_buff *)skb->next;    /* Move along */
skb353net/inet/tcp.c} while(skb != sk->rqueue);
skb487net/inet/tcp.cstruct sk_buff *skb;
skb495net/inet/tcp.cif ((skb=skb_peek(&sk->rqueue)) != NULL) 
skb497net/inet/tcp.cif (sk->copied_seq+1 == skb->h.th->seq && skb->h.th->urg) 
skb598net/inet/tcp.cstatic void tcp_send_skb(struct sock *sk, struct sk_buff *skb)
skb603net/inet/tcp.csize = skb->len - ((unsigned char *) skb->h.th - skb->data);
skb606net/inet/tcp.cif (size < sizeof(struct tcphdr) || size > skb->len) {
skb608net/inet/tcp.cskb, skb->data, skb->h.th, skb->len);
skb609net/inet/tcp.ckfree_skb(skb, FREE_WRITE);
skb616net/inet/tcp.cif(!skb->h.th->syn && !skb->h.th->fin) {
skb618net/inet/tcp.ckfree_skb(skb,FREE_WRITE);
skb624net/inet/tcp.ctcp_send_check(skb->h.th, sk->saddr, sk->daddr, size, sk);
skb626net/inet/tcp.cskb->h.seq = sk->send_seq;
skb634net/inet/tcp.cskb->next = NULL;
skb635net/inet/tcp.cskb->magic = TCP_WRITE_QUEUE_MAGIC;
skb637net/inet/tcp.csk->wfront=skb;
skb639net/inet/tcp.csk->wback->next = skb;
skb641net/inet/tcp.csk->wback = skb;
skb647net/inet/tcp.csk->prot->queue_xmit(sk, skb->dev, skb, 0);
skb653net/inet/tcp.cstruct sk_buff * skb;
skb658net/inet/tcp.cskb = sk->partial;
skb659net/inet/tcp.cif (skb) {
skb664net/inet/tcp.creturn skb;
skb669net/inet/tcp.cstruct sk_buff *skb;
skb673net/inet/tcp.cwhile ((skb = tcp_dequeue_partial(sk)) != NULL)
skb674net/inet/tcp.ctcp_send_skb(sk, skb);
skb677net/inet/tcp.cvoid tcp_enqueue_partial(struct sk_buff * skb, struct sock * sk)
skb687net/inet/tcp.csk->partial = skb;
skb815net/inet/tcp.cstruct sk_buff *skb;
skb909net/inet/tcp.cif ((skb = tcp_dequeue_partial(sk)) != NULL) {
skb913net/inet/tcp.chdrlen = ((unsigned long)skb->h.th - (unsigned long)skb->data)
skb918net/inet/tcp.ccopy = min(sk->mss - (skb->len - hdrlen), len);
skb925net/inet/tcp.cmemcpy_fromfs(skb->data + skb->len, from, copy);
skb926net/inet/tcp.cskb->len += copy;
skb932net/inet/tcp.cif ((skb->len - hdrlen) >= sk->mss ||
skb935net/inet/tcp.ctcp_send_skb(sk, skb);
skb937net/inet/tcp.ctcp_enqueue_partial(skb, sk);
skb969net/inet/tcp.cskb = prot->wmalloc(sk, sk->mtu + 128 + prot->max_header + sizeof(*skb), 0, GFP_KERNEL);
skb971net/inet/tcp.csend_tmp = skb;
skb975net/inet/tcp.cskb = prot->wmalloc(sk, copy + prot->max_header + sizeof(*skb), 0, GFP_KERNEL);
skb980net/inet/tcp.cif (skb == NULL) {
skb1009net/inet/tcp.cskb->len = 0;
skb1010net/inet/tcp.cskb->sk = sk;
skb1011net/inet/tcp.cskb->free = 0;
skb1013net/inet/tcp.cbuff = skb->data;
skb1019net/inet/tcp.ctmp = prot->build_header(skb, sk->saddr, sk->daddr, &dev,
skb1020net/inet/tcp.cIPPROTO_TCP, sk->opt, skb->mem_len,sk->ip_tos,sk->ip_ttl);
skb1022net/inet/tcp.cprot->wfree(sk, skb->mem_addr, skb->mem_len);
skb1028net/inet/tcp.cskb->len += tmp;
skb1029net/inet/tcp.cskb->dev = dev;
skb1031net/inet/tcp.cskb->h.th =(struct tcphdr *) buff;
skb1034net/inet/tcp.cprot->wfree(sk, skb->mem_addr, skb->mem_len);
skb1045net/inet/tcp.cskb->len += tmp;
skb1051net/inet/tcp.cskb->len += copy;
skb1052net/inet/tcp.cskb->free = 0;
skb1059net/inet/tcp.ctcp_send_skb(sk, skb);
skb1176net/inet/tcp.cstruct sk_buff *skb;
skb1190net/inet/tcp.cwhile((skb=skb_peek(&sk->rqueue)) != NULL ) 
skb1192net/inet/tcp.cif (!skb->used) 
skb1194net/inet/tcp.cskb_unlink(skb);
skb1195net/inet/tcp.cskb->sk = sk;
skb1196net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb1255net/inet/tcp.cstruct sk_buff *skb;
skb1313net/inet/tcp.cskb = skb_peek(&sk->rqueue);
skb1317net/inet/tcp.cif (skb->h.th->urg && !skb->urg_used) {
skb1318net/inet/tcp.cif (skb->h.th->urg_ptr == 0) {
skb1319net/inet/tcp.cskb->h.th->urg_ptr = ntohs(skb->len);
skb1321net/inet/tcp.camt = min(ntohs(skb->h.th->urg_ptr),len);
skb1324net/inet/tcp.cmemcpy_tofs(to,(unsigned char *)(skb->h.th) +
skb1325net/inet/tcp.cskb->h.th->doff*4, amt);
skb1329net/inet/tcp.cskb->urg_used = 1;
skb1336net/inet/tcp.cskb =(struct sk_buff *)skb->next;
skb1337net/inet/tcp.c} while(skb != sk->rqueue);
skb1351net/inet/tcp.cstruct sk_buff *skb;
skb1375net/inet/tcp.cskb=skb_peek(&sk->rqueue);
skb1384net/inet/tcp.cwhile(skb == NULL ||
skb1385net/inet/tcp.cbefore(sk->copied_seq+1, skb->h.th->seq) || skb->used) {
skb1386net/inet/tcp.cDPRINTF((DBG_TCP, "skb = %X:\n", skb));
skb1485net/inet/tcp.cskb=skb_peek(&sk->rqueue);
skb1493net/inet/tcp.coffset = sk->copied_seq+1 - skb->h.th->seq;
skb1495net/inet/tcp.cif (skb->h.th->syn) offset--;
skb1496net/inet/tcp.cif (offset < skb->len) /* Some of the packet is useful */
skb1502net/inet/tcp.cif (skb->h.th->urg) 
skb1504net/inet/tcp.cif (skb->urg_used) 
skb1506net/inet/tcp.csk->copied_seq += ntohs(skb->h.th->urg_ptr);
skb1507net/inet/tcp.coffset += ntohs(skb->h.th->urg_ptr);
skb1508net/inet/tcp.cif (offset >= skb->len) 
skb1510net/inet/tcp.cskb->used = 1;
skb1511net/inet/tcp.cskb =(struct sk_buff *)skb->next;
skb1525net/inet/tcp.cused = min(skb->len - offset, len);
skb1527net/inet/tcp.cmemcpy_tofs(to,((unsigned char *)skb->h.th) +
skb1528net/inet/tcp.cskb->h.th->doff*4 + offset, used);
skb1543net/inet/tcp.c(!skb->h.th->urg || skb->urg_used) &&
skb1544net/inet/tcp.c(used + offset >= skb->len)) 
skb1545net/inet/tcp.cskb->used = 1;
skb1551net/inet/tcp.cif (/*skb->h.th->psh || */skb->h.th->urg) 
skb1558net/inet/tcp.cskb->used = 1;
skb1561net/inet/tcp.cskb =(struct sk_buff *)skb->next;
skb1843net/inet/tcp.ctcp_conn_request(struct sock *sk, struct sk_buff *skb,
skb1856net/inet/tcp.csk, skb, daddr, saddr, opt, dev));
skb1858net/inet/tcp.cth = skb->h.th;
skb1866net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb1875net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb1889net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb1923net/inet/tcp.cnewsk->acked_seq = skb->h.th->seq+1;
skb1924net/inet/tcp.cnewsk->fin_seq = skb->h.th->seq;
skb1925net/inet/tcp.cnewsk->copied_seq = skb->h.th->seq;
skb1936net/inet/tcp.cnewsk->dummy_th.source = skb->h.th->dest;
skb1937net/inet/tcp.cnewsk->dummy_th.dest = skb->h.th->source;
skb1953net/inet/tcp.cnewsk->acked_seq = skb->h.th->seq + 1;
skb1954net/inet/tcp.cnewsk->copied_seq = skb->h.th->seq;
skb1958net/inet/tcp.cnewsk->ip_tos=skb->ip_hdr->tos;
skb1978net/inet/tcp.ctcp_options(newsk,skb->h.th);
skb1985net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb2007net/inet/tcp.cskb->sk = sk;
skb2008net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb2015net/inet/tcp.cmemcpy(t1, skb->h.th, sizeof(*t1));
skb2019net/inet/tcp.ct1->dest = skb->h.th->source;
skb2031net/inet/tcp.ct1->ack_seq = ntohl(skb->h.th->seq+1);
skb2044net/inet/tcp.cskb->sk = newsk;
skb2047net/inet/tcp.csk->rmem_alloc -= skb->mem_len;
skb2048net/inet/tcp.cnewsk->rmem_alloc += skb->mem_len;
skb2050net/inet/tcp.cskb_queue_tail(&sk->rqueue,skb);
skb2081net/inet/tcp.cstruct sk_buff *skb;
skb2084net/inet/tcp.cwhile((skb=skb_dequeue(&sk->rqueue))!=NULL)
skb2086net/inet/tcp.cif(skb->len > 0 && after(skb->h.th->seq + skb->len + 1 , sk->copied_seq))
skb2088net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb2210net/inet/tcp.cstruct sk_buff *skb;
skb2225net/inet/tcp.cskb = sk->wfront;
skb2226net/inet/tcp.cIS_SKB(skb);
skb2227net/inet/tcp.csk->wfront =(struct sk_buff *)skb->next;
skb2229net/inet/tcp.cskb->next = NULL;
skb2230net/inet/tcp.cif (skb->magic != TCP_WRITE_QUEUE_MAGIC) {
skb2232net/inet/tcp.c"queue\n", skb->magic);
skb2237net/inet/tcp.cskb->magic = 0;
skb2241net/inet/tcp.cif (before(skb->h.seq, sk->rcv_ack_seq +1)) {
skb2243net/inet/tcp.ckfree_skb(skb, FREE_WRITE);
skb2246net/inet/tcp.csk->prot->queue_xmit(sk, skb->dev, skb, skb->free);
skb2260net/inet/tcp.cstruct sk_buff *skb,*skb2,*skb3;
skb2262net/inet/tcp.cfor (skb = sk->send_head; skb != NULL; skb = skb2) {
skb2263net/inet/tcp.cskb2 = (struct sk_buff *)skb->link3;
skb2265net/inet/tcp.cskb->link3 = list;
skb2266net/inet/tcp.csk->send_tail = skb;
skb2267net/inet/tcp.clist = skb;
skb2271net/inet/tcp.cbefore(skb->h.seq, skb3->link3->h.seq)) {
skb2272net/inet/tcp.cskb->link3 = skb3->link3;
skb2273net/inet/tcp.cskb3->link3 = skb;
skb2274net/inet/tcp.cif (skb->link3 == NULL) sk->send_tail = skb;
skb2335net/inet/tcp.cstruct sk_buff *skb;
skb2348net/inet/tcp.cskb = skb2;
skb2349net/inet/tcp.cskb2 = (struct sk_buff *)skb->link3;
skb2350net/inet/tcp.cskb->link3 = NULL;
skb2351net/inet/tcp.cif (after(skb->h.seq, sk->window_seq)) {
skb2354net/inet/tcp.cif (skb->next != NULL) {
skb2355net/inet/tcp.cskb_unlink(skb);        
skb2358net/inet/tcp.cskb->magic = TCP_WRITE_QUEUE_MAGIC;
skb2360net/inet/tcp.cskb->next = sk->wfront;
skb2361net/inet/tcp.csk->wfront = skb;
skb2363net/inet/tcp.cskb->next = wskb->next;
skb2364net/inet/tcp.cwskb->next = skb;
skb2366net/inet/tcp.cif (sk->wback == wskb) sk->wback = skb;
skb2367net/inet/tcp.cwskb = skb;
skb2370net/inet/tcp.csk->send_head = skb;
skb2371net/inet/tcp.csk->send_tail = skb;
skb2373net/inet/tcp.csk->send_tail->link3 = skb;
skb2374net/inet/tcp.csk->send_tail = skb;
skb2376net/inet/tcp.cskb->link3 = NULL;
skb2660net/inet/tcp.ctcp_data(struct sk_buff *skb, struct sock *sk, 
skb2667net/inet/tcp.cth = skb->h.th;
skb2669net/inet/tcp.cskb->len = len -(th->doff*4);
skb2671net/inet/tcp.cDPRINTF((DBG_TCP, "tcp_data len = %d sk = %X:\n", skb->len, sk));
skb2673net/inet/tcp.csk->bytes_rcv += skb->len;
skb2674net/inet/tcp.cif (skb->len == 0 && !th->fin && !th->urg && !th->psh) {
skb2677net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb2682net/inet/tcp.csk->acked_seq = th->seq + skb->len + th->syn + th->fin;
skb2683net/inet/tcp.ctcp_reset(sk->saddr, sk->daddr, skb->h.th,
skb2684net/inet/tcp.csk->prot, NULL, skb->dev, sk->ip_tos, sk->ip_ttl);
skb2689net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb2704net/inet/tcp.cDPRINTF((DBG_TCP, "tcp_data: skb = %X:\n", skb));
skb2706net/inet/tcp.csk->rqueue = skb;
skb2707net/inet/tcp.cskb->next = skb;
skb2708net/inet/tcp.cskb->prev = skb;
skb2709net/inet/tcp.cskb->list = &sk->rqueue;
skb2711net/inet/tcp.cskb_queue_head(&sk->rqueue,skb);
skb2721net/inet/tcp.cprintk("skb->h.th->seq = %ld\n",skb->h.th->seq);
skb2727net/inet/tcp.cskb->prev = skb1;
skb2728net/inet/tcp.cskb->next = skb1->next;
skb2729net/inet/tcp.cskb->next->prev = skb;
skb2730net/inet/tcp.cskb1->next = skb;
skb2731net/inet/tcp.cif (skb1 == sk->rqueue) sk->rqueue = skb;
skb2735net/inet/tcp.cskb->next= skb1;
skb2736net/inet/tcp.cskb->prev = skb1->prev;
skb2737net/inet/tcp.cskb->prev->next = skb;
skb2738net/inet/tcp.cskb1->prev = skb;
skb2744net/inet/tcp.cif (th->seq==skb1->h.th->seq && skb->len>= skb1->len)
skb2746net/inet/tcp.cskb_append(skb1,skb);
skb2755net/inet/tcp.cskb_append(skb1,skb);
skb2760net/inet/tcp.cskb_queue_head(&sk->rqueue, skb);    
skb2765net/inet/tcp.cDPRINTF((DBG_TCP, "skb = %X:\n", skb));
skb2768net/inet/tcp.cth->ack_seq = th->seq + skb->len;
skb2782net/inet/tcp.cskb->acked = 1;
skb2785net/inet/tcp.cif (skb->h.th->fin) {
skb2790net/inet/tcp.cfor(skb2 = (struct sk_buff *)skb->next;
skb2846net/inet/tcp.cif (!skb->acked) {
skb2989net/inet/tcp.cstruct sk_buff *skb;
skb3006net/inet/tcp.cwhile((skb = get_firstr(sk)) == NULL) {
skb3026net/inet/tcp.cnewsk = skb->sk;
skb3028net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3227net/inet/tcp.ctcp_rcv(struct sk_buff *skb, struct device *dev, struct options *opt,
skb3234net/inet/tcp.cif (!skb) {
skb3252net/inet/tcp.cth = skb->h.th;
skb3257net/inet/tcp.cDPRINTF((DBG_TCP, "len = %d, redo = %d, skb=%X\n", len, redo, skb));
skb3270net/inet/tcp.cskb->sk = NULL;
skb3273net/inet/tcp.ckfree_skb(skb,FREE_READ);
skb3287net/inet/tcp.ctcp_reset(daddr, saddr, th, &tcp_prot, opt,dev,skb->ip_hdr->tos,255);
skb3289net/inet/tcp.cskb->sk = NULL;
skb3290net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3294net/inet/tcp.cskb->len = len;
skb3295net/inet/tcp.cskb->sk = sk;
skb3296net/inet/tcp.cskb->acked = 0;
skb3297net/inet/tcp.cskb->used = 0;
skb3298net/inet/tcp.cskb->free = 0;
skb3299net/inet/tcp.cskb->urg_used = 0;
skb3300net/inet/tcp.cskb->saddr = daddr;
skb3301net/inet/tcp.cskb->daddr = saddr;
skb3309net/inet/tcp.csk->back_log = skb;
skb3310net/inet/tcp.cskb->next = skb;
skb3311net/inet/tcp.cskb->prev = skb;
skb3313net/inet/tcp.cskb->next = sk->back_log;
skb3314net/inet/tcp.cskb->prev = sk->back_log->prev;
skb3315net/inet/tcp.cskb->prev->next = skb;
skb3316net/inet/tcp.cskb->next->prev = skb;
skb3336net/inet/tcp.cif (sk->rmem_alloc + skb->mem_len >= sk->rcvbuf) {
skb3337net/inet/tcp.cskb->sk = NULL;
skb3339net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3343net/inet/tcp.csk->rmem_alloc += skb->mem_len;
skb3362net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3380net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3403net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3420net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3426net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3433net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3439net/inet/tcp.cif (tcp_data(skb, sk, saddr, len)) {
skb3440net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3447net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3458net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3468net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3474net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3480net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3500net/inet/tcp.ctcp_conn_request(sk, skb, daddr, saddr, opt, dev);
skb3505net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3511net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3525net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3538net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3548net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3558net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3568net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3583net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3621net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3626net/inet/tcp.cif (tcp_data(skb, sk, saddr, len))
skb3627net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3636net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3642net/inet/tcp.cif (tcp_data(skb, sk, saddr, len)) {
skb3643net/inet/tcp.ckfree_skb(skb, FREE_READ);
skb3733net/inet/tcp.cstruct sk_buff *skb2, *skb;
skb3745net/inet/tcp.cskb = sk->wfront;
skb3746net/inet/tcp.cif (skb == NULL)
skb3749net/inet/tcp.cdev = skb->dev;
skb3756net/inet/tcp.cIS_SKB(skb);
skb3758net/inet/tcp.craw = skb->data;
skb3762net/inet/tcp.cdata = skb->len - hlen - sizeof(struct tcphdr);
skb3773net/inet/tcp.cskb2->arp = skb->arp;
skb120net/inet/tcp.hextern int  tcp_rcv(struct sk_buff *skb, struct device *dev,
skb219net/inet/udp.cstruct sk_buff *skb;
skb237net/inet/udp.cskb = sk->prot->wmalloc(sk, size, 0, GFP_KERNEL);
skb238net/inet/udp.cif (skb == NULL) return(-ENOMEM);
skb240net/inet/udp.cskb->mem_addr = skb;
skb241net/inet/udp.cskb->mem_len  = size;
skb242net/inet/udp.cskb->sk       = NULL;  /* to avoid changing sk->saddr */
skb243net/inet/udp.cskb->free     = 1;
skb244net/inet/udp.cskb->arp      = 0;
skb247net/inet/udp.cbuff = skb->data;
skb251net/inet/udp.csaddr, sin->sin_addr.s_addr, dev, IPPROTO_UDP, skb->mem_len));
skb252net/inet/udp.ctmp = sk->prot->build_header(skb, saddr, sin->sin_addr.s_addr,
skb253net/inet/udp.c&dev, IPPROTO_UDP, sk->opt, skb->mem_len,sk->ip_tos,sk->ip_ttl);
skb254net/inet/udp.cskb->sk=sk;  /* So memory is freed correctly */
skb257net/inet/udp.csk->prot->wfree(sk, skb->mem_addr, skb->mem_len);
skb264net/inet/udp.cskb->len = tmp + sizeof(struct udphdr) + len;  /* len + UDP + IP + MAC */
skb265net/inet/udp.cskb->dev = dev;
skb274net/inet/udp.cif (skb->len > 4095)
skb278net/inet/udp.csk->prot->wfree(sk, skb->mem_addr, skb->mem_len);
skb293net/inet/udp.cudp_send_check(uh, saddr, sin->sin_addr.s_addr, skb->len - tmp, sk);
skb296net/inet/udp.csk->prot->queue_xmit(sk, dev, skb, 1);
skb401net/inet/udp.cstruct sk_buff *skb;
skb406net/inet/udp.cskb = sk->rqueue;
skb407net/inet/udp.cif (skb != NULL) {
skb413net/inet/udp.camount = skb->len;
skb440net/inet/udp.cstruct sk_buff *skb;
skb476net/inet/udp.cskb=skb_recv_datagram(sk,flags,noblock,&er);
skb477net/inet/udp.cif(skb==NULL)
skb479net/inet/udp.ccopied = min(len, skb->len);
skb482net/inet/udp.cskb_copy_datagram(skb,sizeof(struct udphdr),to,copied);
skb489net/inet/udp.caddr.sin_port = skb->h.uh->source;
skb490net/inet/udp.caddr.sin_addr.s_addr = skb->daddr;
skb494net/inet/udp.cskb_free_datagram(skb);
skb547net/inet/udp.cudp_rcv(struct sk_buff *skb, struct device *dev, struct options *opt,
skb554net/inet/udp.cuh = (struct udphdr *) skb->h.uh;
skb560net/inet/udp.cicmp_send(skb, ICMP_DEST_UNREACH, ICMP_PORT_UNREACH, dev);
skb567net/inet/udp.cskb->sk = NULL;
skb568net/inet/udp.ckfree_skb(skb, FREE_WRITE);
skb574net/inet/udp.cskb->sk = NULL;
skb575net/inet/udp.ckfree_skb(skb, FREE_WRITE);
skb579net/inet/udp.cskb->sk = sk;
skb580net/inet/udp.cskb->dev = dev;
skb581net/inet/udp.cskb->len = len;
skb584net/inet/udp.cskb->daddr = saddr;
skb585net/inet/udp.cskb->saddr = daddr;
skb589net/inet/udp.cif (sk->rmem_alloc + skb->mem_len >= sk->rcvbuf) 
skb591net/inet/udp.cskb->sk = NULL;
skb592net/inet/udp.ckfree_skb(skb, FREE_WRITE);
skb596net/inet/udp.csk->rmem_alloc += skb->mem_len;
skb604net/inet/udp.cskb_queue_tail(&sk->rqueue,skb);
skb606net/inet/udp.cskb->len = len - sizeof(*uh);
skb609net/inet/udp.csk->data_ready(sk,skb->len);
skb43net/inet/udp.hextern int  udp_rcv(struct sk_buff *skb, struct device *dev,