亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ip.c

?? webserve1.0
?? C
字號:
/* IP functions for 'TCP/IP Lean' (c) Iosoft Ltd. 2000

This software is only licensed for distribution with the book 'TCP/IP Lean',
and may only be used for personal experimentation by the purchaser
of that book, on condition that this copyright notice is retained.
For commercial licensing, contact license@iosoft.co.uk

This is experimental software; use it entirely at your own risk. The author
offers no warranties of any kind, including its fitness for purpose. */

/*
** v0.02 JPB 29/7/97 Added ESLIP packet type
**                   Fixed UDP packet length calculation
** v0.03 JPB 12/8/97 Added incrementing ICMP sequence number (was random!)
** v0.04 JPB 15/8/97 Improved speed of checksum algorithm
** v0.05 JPB 20/8/97 Removed byte-swapping on ICMP seq
** v0.06 JPB 9/1/98  Added assembly-language insert
** v0.07 JPB 18/1/00 Added receive framentation
** v0.08 JPB 24/1/00 Removed subframe ptrs - subframe is now appended to frame
**                   IP headers with options are now resized
** v0.09 JPB 1/3/00  Fixed 'gate_ip' problem when no gateway specified
** v0.10 JPB 23/3/00 Moved 'atoip' to netutil.c
**                   Added 'get_locnode' function pointer
** v0.11 JPB 29/3/00 Moved 'csum' to NETUTIL.C
** v0.12 JPB 3/7/00  Revised header for book CD
*/

/* Debug option to send IP datagrams with a dummy 'options' field */
#define BIGHEAD 0       /* Set non-zero to send datagrams with larger IP hdrs */

#include <stdio.h>
#include <string.h>
#include <ctype.h>

#include "ether.h"
#include "netutil.h"
#include "ip.h"
#include "uart.h"

#define IP_TTL          100     /* Time To Live for an outgoing IP datagram */
#define FRAGTRIES       8       /* Number of attempts to match a fragment */
#define NFRAGS          4       /* No of fragments in buffer */

typedef struct {                /* Fragment buffer structure */
    int tries;                      /* Number of times to attempt a match */
    WORD ident;                     /* IP ident field */
    LWORD sip;                      /* Source IP address */
    WORD oset;                      /* Offset in IP data area */
    WORD len;                       /* Length of fragment */
    BYTE data[MAXIP];               /* Fragment data */
} FRAG;

FRAG frags[NFRAGS];             /* Fragment buffer */

extern int netdebug;            /* Debug flag: net packet display */
extern GENFRAME genframe; 
/* Upcall function pointer: 0 if unused */
NODE *(*get_locnode_n)(int n);  /* Func ptr for local node locator upcall */

/* Private prototypes */
int defrag_ip(IPKT *ip, int dlen);

/* Check ARP packet, swap bytes, return -1, 0 if not ARP */
int is_arp(GENFRAME *gfp, int len)
{
    WORD pcol,hardtype,arppro;
   // ARPKT *arp;
    int dlen=0;

    pcol = getframe_pcol(gfp);          /* ARP only on Ether */
    if (pcol==PCOL_ARP && len>=sizeof(ARPKT))
     {                                   /* If protocol OK.. */
  //      arp =(ARPKT *) getframe_datap(gfp);
  //      swap_arp(gfp);                  /* ..check ARP data */
  //      if (arp->hrd==HTYPE && arp->pro==ARPPRO)
  //          dlen = -1;                  /* Return non-zero if OK */
  //      else
  //      {
  //          dlen = 0;                   /* Swap back if not OK */
  //          swap_arp(gfp);
  //      }
  //  }
         hardtype=gfp->buff[0xe];   //硬件類型
         hardtype=(hardtype<<8)+gfp->buff[0xf];
         arppro=gfp->buff[0x10];   //協議類型
         arppro=(arppro<<8)+gfp->buff[0x11];
         if((hardtype==HTYPE)&&(arppro==ARPPRO))
            dlen=-1; 
     }
    return(dlen);
}

/* Make an ARP packet, return its total length */
int make_arp(GENFRAME *gfp, NODE *srcep, NODE *destp, WORD code)
{
    ARPKT *arp;

    gfp->g.fragoff = 0;                 /* No fragmentation */
    arp =getframe_datap(gfp);
    //arp=&(gfp->buff[0xc]);
   // arp=&(genframe.buff[0xe]);
    memcpy(arp->smac, srcep->mac, MACLEN);  /* Srce ARP ether addr */
    memcpy(arp->dmac, destp->mac, MACLEN);  /* Dest ARP ether addr */
    arp->hrd = HTYPE;                   /* Hware & protocol types */
    arp->pro = ARPPRO;
    arp->hln = MACLEN;                  /* Hardware addr len */
    arp->pln = sizeof(LWORD);           /* IP addr len */
    arp->op  = code;                    /* ARP opcode */
    arp->dip = gate_ip(destp, srcep);   /* Dest ip addr (maybe gateway) */
    arp->sip = srcep->ip;               /* Source IP addr */
    swap_arp(gfp);
   // return(sizeof( ARPKT)+12);
    return(make_frame(gfp, destp->mac, srcep->mac,PCOL_ARP, sizeof(ARPKT)));
}

/* Swap byte order of ints in ARP header */
void swap_arp(GENFRAME *gfp)
{
    ARPKT *arp;
  //  arp=&(genframe.buff[0xe]); 
    arp =(ARPKT *) getframe_datap(gfp);
    arp->hrd = swapw(arp->hrd);
    arp->pro = swapw(arp->pro);
    arp->op = swapw(arp->op);
    arp->sip = swapl(arp->sip);
    arp->dip = swapl(arp->dip);
}

/* Check frame is IP/SLIP, checksum & byte-swap, return data len */
int is_ip(GENFRAME *gfp, int len)
{
    int ver, dlen=0, hlen;
    WORD pcol, sum;
    IPKT *ip;
    
    pcol = getframe_pcol(gfp);
    if ((pcol==PCOL_IP || pcol==0) && len>=sizeof(IPHDR))
    {
     //   ip=&(gfp->buff[0xe]);
        ip = getframe_datap(gfp);           /* Get pointer to IP frame */
        ver = ip->i.vhl >> 4;               /* Get IP version & hdr len */
        hlen = (ip->i.vhl & 0xf) << 2;
        sum = ~csum(&ip->i, (WORD)hlen);    /* Do checksum */
        if (ver==4 && len>=hlen && sum==0)  /* If OK.. */
        {
            swap_ip(gfp);                   /* Do byte-swaps */
            dlen = mini(ip->i.len, len) - hlen;
            if (hlen >= sizeof(IPHDR))       /* If IP options present.. */
            {                               /* ..delete them, move data down */
                memmove(ip->data, &ip->data[hlen-sizeof(IPHDR)], len);
                dlen -= hlen-sizeof(IPHDR);
            }
            if ((ip->i.frags & 0x3fff)!=0)  /* If a fragment.. */
                dlen = defrag_ip(ip, dlen); /* ..call defragmenter */
        }
        else if (netdebug)
            printf("Invalid datagram, ver %u len %u sum %u\n", ver, len, sum);
    }
    return(dlen);
}

/* Make an IP packet, if greater than the MTU, also make fragment (subframe) in
** this frame. Return total length of frame and subframes (if any) */
int make_ip(GENFRAME *gfp, NODE *srcep, NODE *destp, BYTE pcol, WORD dlen)
{
    IPKT *ip, *ip2;
    int len, sublen=0, fhlen, mtu;
    static WORD ident=1, oset=0;
    GENFRAME *sfp;

    ip =(IPKT *) getframe_datap(gfp);           /* Get pointer to IP datagram */
    ip->i.ident = ident;                /* Set datagram ident */
    ip->i.frags = oset >> 3;            /* Frag offset in units of 8 bytes */
    gfp->g.fragoff = 0;                 /* ..assuming no more frags */
    mtu = (getframe_mtu(gfp)-sizeof(IPHDR)) & 0xfff8;   /* MTU rounded down 8 */
    len = mini(dlen, mtu);              /* Size of this frame (this fragment) */
    if (dlen > len)                     /* If fragmentation required.. */
    {                                   /* Create new frag within this frame */
        fhlen = dtype_hdrlen(gfp->g.dtype);             /* Frame hdr len */
        gfp->g.fragoff = len + sizeof(IPHDR) + fhlen;   /* Subframe offset */
        sfp = (GENFRAME *)&gfp->buff[gfp->g.fragoff];   /* Subframe ptr */
        ip->i.frags = (oset>>3)+0x2000;                 /* Show there is frag */
        oset += len;                                    /* New data offset */
        ip2 = (IPKT*)((BYTE*)sfp+sizeof(GENHDR)+fhlen); /* Ptr to 2nd IP frag */
        memmove(ip2->data, &ip->data[oset], dlen-len);  /* Copy data 1st->2nd */
        sfp->g.dtype = gfp->g.dtype;    /* Copy driver type into subframe */
        sublen = make_ip(sfp, srcep, destp, pcol, (WORD)(dlen-len));
    }                                   /* Recursive call to make frag */
    ip->i.vhl = 0x40+(sizeof(IPHDR)>>2);/* Version 4, header len 5 LWORDs */
    ip->i.service = 0;                  /* Routine message */
    ip->i.ttl = IP_TTL;                 /* Time To Live */
    ip->i.pcol = pcol;                  /* Set IP protocol */
    ip->i.sip = srcep->ip;              /* Srce, dest IP addrs */
    ip->i.dip = destp->ip;
#if BIGHEAD
    ip->i.option = 0;                   /* Null options if oversized header */
#endif
    ip->i.len = len + sizeof(IPHDR);    /* Data length */
    swap_ip(gfp);                       /* Do byte-swaps (for checksum) */
    ip->i.check = 0;                    /* Clear checksum */
    ip->i.check = ~csum(ip, sizeof(IPHDR)); /* ..then set to calc value */
    ident++;                            /* Increment datagram ident */
    oset = 0;                           /* Clear fragment offset */
    len += sizeof(IPHDR) + sublen;      /* Bump up length */
    return(make_frame(gfp, destp->mac, srcep->mac,PCOL_IP, (WORD)len));
}

/* Swap byte order of ints in IP header */
void swap_ip(GENFRAME *gfp)
{
    IPHDR *iph;

    iph =(IPHDR *) getframe_datap(gfp);
    //iph =&(gfp->buff[0xe]);
    iph->len = swapw(iph->len);
    iph->ident = swapw(iph->ident);
    iph->frags = swapw(iph->frags);
    iph->sip = swapl(iph->sip);
    iph->dip = swapl(iph->dip);
}

/* Return the maximum IP data size for a given frame without fragmentation */
int ip_maxdata(GENFRAME *gfp)
{
    return(maxi(getframe_mtu(gfp)-sizeof(IPHDR), 0));
}

/* Defragment an incoming IP datagram by matching with existing fragments
** This function handles a maximum of 2 fragments per datagram
** Return total IP data length, 0 if datagram is incomplete */
int defrag_ip(IPKT *ip, int dlen)
{
    int n=0, match=0;
    WORD oset;
    FRAG *fp, *fp2=0;

    oset = (ip->i.frags & 0x1fff) << 3; /* Get offset for imcoming frag */
    while (n<NFRAGS && !match)          /* Search for matching half */
    {
        fp = &frags[n++];
        if (fp->tries)
        {                               /* ..by checking ident */
            if (!(match = (ip->i.ident==fp->ident && ip->i.sip==fp->sip)))
                fp->tries--;            /* If no match, reduce attempts left */
        }
        else
            fp2 = fp;
    }
    if (match)
    {                                   /* Matched: check isn't a duplicate */
        if ((oset+dlen == fp->oset || fp->oset+fp->len == oset) &&
            dlen+fp->len <= MAXGEN)     /* ..and length is OK */
        {
            if (oset)                   /* Move old data as necessary */
                memmove(&ip->data[oset], ip->data, dlen);
            ip->i.len = dlen += fp->len;/* ..and add in new data */
            memcpy(&ip->data[fp->oset], fp->data, fp->len);
            fp->tries = 0;
        }
        else
        {
            if (netdebug)
                printf("Mismatched frag oset %u buff len %u\n", oset, fp->len);
            match = 0;
        }
    }
    else if (fp2)                       /* No match, but there is spare space */
    {
        fp2->tries = FRAGTRIES;         /* Save frag for matching later */
        fp2->ident = ip->i.ident;
        fp2->sip = ip->i.sip;
        fp2->oset = oset;
        fp2->len = dlen;
        memcpy(fp2->data, ip->data, dlen);
    }
    return(match ? dlen : 0);
}

/* Find local node corresponding to given IP addr, return 0 if not found */
NODE *findloc_ip(LWORD locip)
{
    NODE *np=0;
    int n=0;

    while (get_locnode_n && (np=get_locnode_n(n))!=0 && np->ip!=locip)
        n++;
    return(np);
}

/* Get the frame driver type, source IP and Ethernet addresses
** Returned data does not include port number, netmask or gateway addr */
void getip_srce(GENFRAME *gfp, NODE *np)
{
    IPHDR *iph;

    np->dtype = gfp->g.dtype;
    getframe_srce(gfp, np->mac);
    iph =(IPHDR *) getframe_datap(gfp);
  //  iph=&(gfp->buff[0xe]);
    np->ip = iph->sip;
}

/* Get the frame driver type, destination IP and Ethernet addresses
** Returned data does not include port number, netmask or gateway addr */
void getip_dest(GENFRAME *gfp, NODE *np)
{
    IPHDR *iph;

    np->dtype = gfp->g.dtype;
    getframe_dest(gfp, np->mac);
    iph =(IPHDR *) getframe_datap(gfp);
    np->ip = iph->dip;
}

/* Get local node data corresponding to a frame destination IP address
** Data does not include port number. Return 0 if no matching local node */
int getip_locdest(GENFRAME *gfp, NODE *np)
{
    IPHDR *iph;
    NODE *locp;
    int ok=0;

    iph =(IPHDR *) getframe_datap(gfp);
    ok = (locp = findloc_ip(iph->dip)) != 0;
    if (ok)
        *np = *locp;
    return(ok);
}

/* Check a remote address to see if it is on the local subnet.
** If so (or no gateway), return it. If not, return the gateway IP address */
LWORD gate_ip(NODE *remp, NODE *locp)
{//LWORD ip;
   if(((remp->ip)&(locp->mask))==((locp->ip)&(locp->mask)))
      return(remp->ip);
   else
      return(locp->gate);   
    
   // return((locp->gate==0||on_subnet(remp->ip, locp)) ? remp->ip : locp->gate);
}

/* Check an IP address to see if it is on a subnet, return 0 if not */
int on_subnet(LWORD remip, NODE *locp)
{
    return(((remip ^ locp->ip) & locp->mask) == 0);
}

/* Return ICMP data length (-1 if no data), 0 if not ICMP */
int is_icmp(IPKT *ip, int len)
{
    ICMPKT *icmp;
    WORD sum;
    int dlen=0;

    if (ip->i.pcol==PICMP && len>=sizeof(ICMPHDR))
    {
        icmp = (ICMPKT *)ip;
        if ((sum=csum(&icmp->c, (WORD)len)) == 0xffff)
        {
            swap_icmp(icmp);
            dlen =(len>sizeof(ICMPHDR)) ? len-sizeof(ICMPHDR) : (-1);
        }
        else
            printf("\nICMP checksum error: %04X\n", sum);
    }
    return(dlen);
}

/* Make an ICMP packet */
int make_icmp(GENFRAME *gfp, NODE *srcep, NODE *destp, BYTE type, BYTE code,
    WORD dlen)
{
    ICMPKT *icmp;
    WORD len;

    icmp =(ICMPKT *) getframe_datap(gfp);
    icmp->c.type = type;
    icmp->c.code = code;
    icmp->c.check = 0;
    swap_icmp(icmp);
    len = (WORD)(dlen + sizeof(ICMPHDR));
    icmp->c.check = ~csum(&icmp->c, len);
    return(make_ip(gfp, srcep, destp, PICMP, len));
}

/* Make ICMP 'destination unreachable' for incoming frame */
int icmp_unreach(GENFRAME *gfp, NODE *srcep, NODE *destp, BYTE code)
{
    int len;
    ICMPKT *icmp;

    icmp =(ICMPKT *) getframe_datap(gfp);
    len = ((icmp->i.vhl & 0xf) << 2) + 8;
    swap_ip(gfp);
    memmove(icmp->data, icmp, len);
    return(make_icmp(gfp, srcep, destp, ICUNREACH, code, (WORD)len));
}

/* Swap byte order of ints in ICMP header */
void swap_icmp(ICMPKT *icmp)
{
    icmp->c.ident = swapw(icmp->c.ident);
    icmp->c.seq = swapw(icmp->c.seq);
}

/* Return the maximum ICMP data size for a given frame without fragmentation */
int icmp_maxdata(GENFRAME *gfp)
{
    return(maxi(ip_maxdata(gfp)-sizeof(ICMPHDR), 0));
}

/* EOF */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品免费在线观看| 伊人一区二区三区| 91麻豆精品国产91久久久使用方法 | 欧美一级在线免费| 欧美日韩国产美| 欧美日韩国产首页在线观看| 欧美日韩日本视频| 欧美色爱综合网| 欧美日韩一区久久| 欧美久久久久久久久中文字幕| 欧美性极品少妇| 欧美日韩激情在线| 日韩三级精品电影久久久 | 国产欧美精品在线观看| 久久久不卡影院| 中文字幕精品三区| 中文字幕一区在线观看视频| 中文字幕一区二区三区四区不卡| 国产偷国产偷精品高清尤物| 国产精品美日韩| 国产色产综合产在线视频| 国产精品久久久久久久第一福利| 亚洲欧美中日韩| 国产精品视频免费| 国产精品区一区二区三| 亚洲男人天堂av网| 亚洲第一成人在线| 美女网站色91| 国产在线一区观看| 91免费版在线看| 欧美日韩综合在线免费观看| 91精品福利在线一区二区三区 | 一区二区三区欧美在线观看| 午夜视频久久久久久| 久久爱www久久做| 风间由美性色一区二区三区| 色视频成人在线观看免| 91精品一区二区三区在线观看| 欧美成人一级视频| 国产精品美女久久久久久久久 | av在线不卡免费看| 欧美日韩精品一区二区三区| 精品成人私密视频| 亚洲视频在线一区| 美女性感视频久久| 成人免费观看男女羞羞视频| 欧美在线999| 精品理论电影在线观看| 国产精品视频九色porn| 日韩精品视频网站| 成人一区二区在线观看| 欧美片网站yy| 中文字幕av免费专区久久| 亚洲成人1区2区| 国产福利一区二区三区| 欧美日韩免费一区二区三区视频| 久久久久久一二三区| 亚洲午夜国产一区99re久久| 国模娜娜一区二区三区| 精品日韩一区二区| 亚洲精品国产a| 精品一区二区三区免费观看| 色婷婷激情综合| 2021久久国产精品不只是精品| 亚洲综合丝袜美腿| 成人少妇影院yyyy| 欧美一级二级三级乱码| 亚洲免费av在线| 国产凹凸在线观看一区二区| 欧美久久久久中文字幕| 亚洲日本va午夜在线电影| 精品系列免费在线观看| 欧美三级电影在线观看| 国产精品欧美经典| 国产在线精品视频| 91精品国产综合久久国产大片| 综合色中文字幕| 国产黄色91视频| 日韩欧美亚洲国产另类| 亚洲激情图片一区| 粉嫩在线一区二区三区视频| 日韩欧美一区在线观看| 亚洲成人av福利| 色网综合在线观看| 中文字幕一区二区三区精华液 | 欧美一区三区二区| 亚洲高清免费观看高清完整版在线观看| 高清国产一区二区| 久久久综合网站| 青青草原综合久久大伊人精品优势| 91国产成人在线| 亚洲图片另类小说| 成人av电影在线| 国产女同互慰高潮91漫画| 国内精品视频666| 日韩欧美国产午夜精品| 日韩国产欧美在线播放| 欧美日韩国产123区| 亚洲综合男人的天堂| av电影天堂一区二区在线观看| 久久婷婷色综合| 国内一区二区在线| 精品国产乱码久久久久久久| 青椒成人免费视频| 欧美一区二区三区在线观看视频| 婷婷开心久久网| 欧美日韩综合一区| 亚洲成av人片| 欧美剧情片在线观看| 日产欧产美韩系列久久99| 91精品国产综合久久香蕉的特点 | 欧美天天综合网| 一区二区高清视频在线观看| 欧美专区日韩专区| 亚洲成av人片一区二区梦乃| 欧美精品三级在线观看| 青青草国产成人99久久| 日韩精品一区二区在线观看| 久久精品国产免费| 久久日一线二线三线suv| 国产精品一级片| 国产精品对白交换视频| 91亚洲永久精品| 尤物在线观看一区| 欧美高清hd18日本| 麻豆专区一区二区三区四区五区| 26uuu精品一区二区在线观看| 国产激情一区二区三区| 国产精品妹子av| 色噜噜偷拍精品综合在线| www.66久久| 亚洲综合精品久久| 91精品国产综合久久国产大片| 国内精品伊人久久久久av一坑| 欧美国产欧美亚州国产日韩mv天天看完整| 懂色av一区二区夜夜嗨| 亚洲精品国产成人久久av盗摄 | 日本一区二区三区国色天香 | 日韩av一区二| 国产欧美日韩在线看| 色综合一区二区三区| 午夜国产精品一区| 久久免费视频色| 色综合色狠狠综合色| 秋霞电影一区二区| 久久精品无码一区二区三区| 91老师国产黑色丝袜在线| 日韩av一区二| 中文字幕一区二区三区不卡| 91麻豆精品国产91久久久久 | 国产午夜精品在线观看| 91久久精品一区二区三区| 老司机免费视频一区二区三区| 国产欧美日韩另类一区| 欧美在线视频日韩| 国产精品中文欧美| 亚洲一区成人在线| 国产亚洲1区2区3区| 欧美婷婷六月丁香综合色| 韩国欧美国产1区| 一区二区三区在线观看动漫| 欧美一区二区三区日韩| 99精品一区二区三区| 久久激情五月激情| 中文字幕在线一区免费| 7777精品伊人久久久大香线蕉的| 国产 日韩 欧美大片| 视频在线在亚洲| 亚洲欧洲三级电影| 久久一区二区三区国产精品| 欧美日韩高清一区二区不卡| 成人午夜又粗又硬又大| 免费成人在线观看| 亚洲综合男人的天堂| 国产精品久久久一区麻豆最新章节| 日韩一区二区在线观看| 91久久线看在观草草青青| 风间由美一区二区三区在线观看| 免费精品视频最新在线| 亚洲综合色自拍一区| 精久久久久久久久久久| 亚洲国产一区二区三区青草影视 | 青娱乐精品在线视频| 一区二区三区四区激情| 欧美国产精品中文字幕| 欧美电视剧在线看免费| 欧美羞羞免费网站| 一本久久精品一区二区| 床上的激情91.| 九色porny丨国产精品| 日韩电影一二三区| 亚洲一区二区在线免费看| 一色屋精品亚洲香蕉网站| 国产亚洲污的网站| 精品国产露脸精彩对白 | 日韩精品一区二区三区老鸭窝| 色噜噜狠狠成人网p站| 99视频精品全部免费在线| 国产传媒久久文化传媒| 国产一区二区三区不卡在线观看|