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

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

?? ip.c

?? 三星4510 BOOTLOADER全部源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* IP functions for 'TCP/IP Lean' (c) Iosoft Ltd. 2000This software is only licensed for distribution with the book 'TCP/IP Lean',and may only be used for personal experimentation by the purchaserof that book, on condition that this copyright notice is retained.For commercial licensing, contact license@iosoft.co.ukThis is experimental software; use it entirely at your own risk. The authoroffers 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 */#define _CBUFFLEN_ 0x2000           /* Buffer size: MUST be power of 2 */#include <stdio.h>#include <string.h>#include <ctype.h>#include "ether.h"#include "netutil.h"#include "ip.h"//BYTE bcast2[MACLEN] = {BCASTADDR};#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 */#define DATALEN     32              /* Default ICMP data length */static NODE  locnode;                      /* My Ethernet and IP addresses */static NODE  remnode;                       /* Remote Ethernet and IP addresses */WORD txseq, rxseq;                  /* ICMP sequence numbers */BYTE *testdata;                     /* Block of test data */CBUFF rxpkts = {_CBUFFLEN_};        /* Rx and Tx circular packet buffers */CBUFF txpkts = {_CBUFFLEN_};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 *//* 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;    ARPKT *arp;    int dlen=0;    pcol = getframe_pcol(gfp);          /* ARP only on Ether */    if (pcol==PCOL_ARP && len>=sizeof(ARPKT))    {                                   /* If protocol OK.. */        arp = 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);        }    }    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 */    gfp->g.dtype=DTYPE_ETHER;    arp = (ARPKT *)getframe_datap(gfp);    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(make_frame(gfp, destp->mac, PCOL_ARP, sizeof(ARPKT)));}/* Swap byte order of ints in ARP header */void swap_arp(GENFRAME *gfp){    ARPKT *arp;    arp = 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 = 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)         //   i_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 = 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, PCOL_IP, (WORD)len));}/* Swap byte order of ints in IP header */void swap_ip(GENFRAME *gfp){    IPHDR *iph;    iph = getframe_datap(gfp);    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)                i_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;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲人123区| 亚洲精品一二三| 91福利社在线观看| 国产成人自拍网| 五月综合激情婷婷六月色窝| 国产日韩欧美麻豆| 欧美一区二区三区视频免费播放| youjizz国产精品| 激情欧美日韩一区二区| 亚洲成人在线网站| 亚洲美女电影在线| 欧美国产日韩一二三区| 精品sm在线观看| 欧美放荡的少妇| 色婷婷精品久久二区二区蜜臂av| 国产麻豆9l精品三级站| 免费不卡在线观看| 亚洲va中文字幕| 亚洲精品国产无套在线观| 国产日韩三级在线| 久久综合久久99| 欧美不卡一二三| 日韩欧美黄色影院| 制服丝袜激情欧洲亚洲| 欧美午夜在线一二页| 不卡的av电影| 成人av网站免费观看| 国产一区三区三区| 国产在线国偷精品产拍免费yy| 日韩中文字幕1| 偷拍日韩校园综合在线| 亚洲成人激情自拍| 五月天国产精品| 天天操天天综合网| 日韩在线a电影| 免费高清在线视频一区·| 日韩和的一区二区| 日韩电影在线免费| 美女诱惑一区二区| 久久精品国产秦先生| 另类欧美日韩国产在线| 麻豆久久久久久久| 黄色日韩三级电影| 国产成人免费视| 成人av网站在线观看免费| eeuss国产一区二区三区| 91色porny蝌蚪| 在线一区二区三区四区五区| 日本黄色一区二区| 欧美群妇大交群的观看方式| 欧美日韩一区二区三区四区| 777午夜精品免费视频| 91精品在线免费观看| 欧美不卡一区二区三区四区| 国产人成亚洲第一网站在线播放 | 精一区二区三区| 麻豆91免费看| 国产福利精品导航| 91视视频在线观看入口直接观看www | 久久久精品免费网站| 中文字幕欧美区| 夜夜精品视频一区二区| 日本不卡一区二区| 国产精品一区在线| 日本乱人伦aⅴ精品| 欧美一二三区在线| 国产精品日日摸夜夜摸av| 一级日本不卡的影视| 免费看欧美美女黄的网站| 国产91丝袜在线播放0| 日本高清不卡aⅴ免费网站| 欧美一区二区三区免费| 国产精品色眯眯| 丝袜亚洲另类欧美| 国产成a人亚洲| 欧美日韩国产综合久久 | 亚洲综合激情小说| 免费成人小视频| 成人精品电影在线观看| 在线观看一区二区视频| 精品毛片乱码1区2区3区| 国产喷白浆一区二区三区| 亚洲一线二线三线久久久| 国产一区二区三区综合| 日本乱码高清不卡字幕| 久久一留热品黄| 亚洲图片欧美色图| 国产成人综合在线| 欧美三级午夜理伦三级中视频| 久久只精品国产| 亚洲精品视频自拍| 国产精品99久久久久久久女警 | 欧美精品99久久久**| 亚洲国产精品ⅴa在线观看| 五月天网站亚洲| 色综合天天综合网国产成人综合天 | 久久精品国产澳门| 在线免费av一区| 国产欧美日韩激情| 久久精品国产第一区二区三区| 色婷婷一区二区三区四区| 国产亚洲欧美日韩在线一区| 午夜激情久久久| 91在线精品秘密一区二区| 精品久久久久久久一区二区蜜臀| 一区二区三区在线观看欧美| 丁香五精品蜜臀久久久久99网站 | 日本伊人精品一区二区三区观看方式 | 欧美aⅴ一区二区三区视频| 91免费国产视频网站| 久久精品夜色噜噜亚洲a∨| 人人超碰91尤物精品国产| 欧美亚男人的天堂| 亚洲视频在线一区观看| 国产精品一二三| 久久免费偷拍视频| 久久电影网电视剧免费观看| 欧美日本国产视频| 亚洲成人福利片| 欧美伊人久久大香线蕉综合69| 自拍偷拍亚洲综合| 9l国产精品久久久久麻豆| 国产欧美日韩久久| 国产精品一区三区| 国产亚洲制服色| 国产91丝袜在线播放九色| 国产色综合久久| 国产成人夜色高潮福利影视| www激情久久| 国产精品一区一区三区| 久久精品亚洲麻豆av一区二区| 韩国毛片一区二区三区| 精品国产亚洲一区二区三区在线观看 | 一区二区三区精品| 日本韩国视频一区二区| 亚洲精品日日夜夜| 欧美在线小视频| 香蕉成人啪国产精品视频综合网| 在线日韩国产精品| 亚洲亚洲人成综合网络| 欧美日韩成人综合天天影院 | 不卡的电影网站| 国产精品久久久久久户外露出| 北条麻妃国产九九精品视频| 国产精品三级久久久久三级| 91免费看视频| 午夜精品久久久久久久99水蜜桃| 欧美日韩国产影片| 麻豆精品一区二区综合av| 精品伦理精品一区| 成人免费黄色大片| 一区二区三区蜜桃网| 欧美日韩国产成人在线免费| 免费成人av在线| 久久精品亚洲麻豆av一区二区| 成人福利视频在线看| 亚洲久草在线视频| 欧美精品在线观看一区二区| 久久99热狠狠色一区二区| 中文字幕久久午夜不卡| 91麻豆文化传媒在线观看| 丝袜国产日韩另类美女| 日韩欧美成人午夜| 成人免费毛片片v| 香蕉影视欧美成人| 久久这里只有精品6| 91天堂素人约啪| 日韩成人av影视| 国产精品乱码久久久久久| 色94色欧美sute亚洲线路一ni| 蜜桃精品视频在线| 国产精品激情偷乱一区二区∴| 欧美日韩高清一区二区三区| 国产又粗又猛又爽又黄91精品| 亚洲三级在线看| 精品少妇一区二区三区在线播放 | 亚洲风情在线资源站| 久久精品夜色噜噜亚洲a∨| 欧美综合亚洲图片综合区| 看电影不卡的网站| 亚洲蜜桃精久久久久久久| 欧美va亚洲va在线观看蝴蝶网| 99久久精品费精品国产一区二区| 日韩经典一区二区| 亚洲欧洲精品一区二区精品久久久 | 色婷婷av一区二区三区之一色屋| 视频一区二区中文字幕| 国产精品久久一级| 精品久久久影院| 欧日韩精品视频| 国产不卡在线播放| 三级在线观看一区二区 | 亚洲人成人一区二区在线观看| 日韩亚洲欧美高清| 色婷婷综合久久久中文字幕| 国产精品正在播放| 免费亚洲电影在线| 亚洲一区二区三区四区在线观看| 国产日韩欧美精品综合| 91精品国产综合久久精品图片|