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

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

?? ip.c

?? 三星公司的ARM44B0的TCPIP測試程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* IP functions for 'TCP/IP Lean' (c) Iosoft Ltd. 2000

NOTE: replace sizeof(ARPKT) with ARPLEN!!

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 ARPLEN  28
#define IPHDRLEN     20
#define ICMPHDRLEN   8

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

#include "ether.h"
#include "netutil.h"
#include "ip.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 sipp;                      /* 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 WORD swapw(WORD w);
extern LWORD swapl(LWORD lw);
extern void *getframe_datap(GENFRAME *gfp);

/* 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;
    BYTE *temparp;
    int dlen=0;
    ARPKT *arp;
    
    arp=&arpkt;
    pcol = getframe_pcol(gfp);          /* ARP only on Ether */
    if (pcol==PCOL_ARP && len>=sizeof(ARPKT))
    {                                   /* If protocol OK.. */
        temparp =(BYTE * )getframe_datap(gfp);
        //memcpy((BYTE *)arp,temparp,ARPLEN);//sizeof(ARPKT));
        memcpy((BYTE *)(&(arp->hrd)),&temparp[0],sizeof(WORD));
        memcpy((BYTE *)(&(arp->pro)),&temparp[2],sizeof(WORD));
        memcpy((BYTE *)(&(arp->hln)),&temparp[4],sizeof(BYTE));
        memcpy((BYTE *)(&(arp->pln)),&temparp[5],sizeof(BYTE));
        memcpy((BYTE *)(&(arp->op)),&temparp[6],sizeof(WORD));
        memcpy(arp->smac,&temparp[8],MACLEN);
        memcpy((BYTE *)(&(arp->sip)),&temparp[8+MACLEN],sizeof(LWORD));
        memcpy(arp->dmac,&temparp[12+MACLEN],MACLEN);
        memcpy((BYTE *)(&(arp->dip)),&temparp[12+2*MACLEN],sizeof(LWORD));
        
        swap_arp(gfp);                  /* ..check ARP data */
        
        //arp = getframe_datap(gfp);
        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;
    BYTE *temparp;
    LWORD templ;

    gfp->g.fragoff = 0;                 /* No fragmentation */
    temparp = (BYTE *)getframe_datap(gfp);
    memcpy(&temparp[8], srcep->mac, MACLEN);  /* Srce ARP ether addr */
    memcpy(&temparp[12+MACLEN], destp->mac, MACLEN);  /* Dest ARP ether addr */
    temparp[0] = HTYPE>>8;                   /* Hware & protocol types */
    temparp[1] = HTYPE&0xff;
    temparp[2] = ARPPRO>>8;
    temparp[3] = ARPPRO&0xff;
    temparp[4] = MACLEN;                  /* Hardware addr len */
    temparp[5] = sizeof(LWORD);           /* IP addr len */
    temparp[6] = code>>8;                    /* ARP opcode */
    temparp[7] = code&0xff;
    templ = srcep->ip;                     /* Source IP addr */
    temparp[8+MACLEN] = (BYTE)((templ>>24)&0x000000ff);
    temparp[9+MACLEN] = (BYTE)((templ>>16)&0x000000ff);
    temparp[10+MACLEN] = (BYTE)((templ>>8)&0x000000ff);
    temparp[11+MACLEN] = (BYTE)(templ&0x000000ff);
    templ = gate_ip(destp, srcep);               /* Dest ip addr (maybe gateway) */
    temparp[12+2*MACLEN] = (BYTE)((templ>>24)&0x000000ff);
    temparp[13+2*MACLEN] = (BYTE)((templ>>16)&0x000000ff);
    temparp[14+2*MACLEN] = (BYTE)((templ>>8)&0x000000ff);
    temparp[15+2*MACLEN] = (BYTE)(templ&0x000000ff);
    //swap_arp(gfp);
    Uart_Printf("\n");
    /*for(i=0;i<ARPLEN;i++)
    Uart_Printf("%x,",temparp[i]);*/
    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=&arpkt;

    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;
    BYTE *tempip;

    ip=&ipkt;
    //Uart_Printf("\nis_ip");
    pcol = getframe_pcol(gfp);
    if ((pcol==PCOL_IP || pcol==0) && len>=sizeof(IPHDR))
    {
        tempip=(BYTE *)getframe_datap(gfp);
       
//-----------------------------------------------------------------------
        memcpy((BYTE *)(&(ip->i.vhl)),&tempip[0],sizeof(BYTE));
        memcpy((BYTE *)(&(ip->i.service)),&tempip[1],sizeof(BYTE));
        memcpy((BYTE *)(&(ip->i.len)),&tempip[2],sizeof(WORD));
        memcpy((BYTE *)(&(ip->i.ident)),&tempip[4],sizeof(WORD));
        memcpy((BYTE *)(&(ip->i.frags)),&tempip[6],sizeof(WORD));
        memcpy((BYTE *)(&(ip->i.ttl)),&tempip[8],sizeof(BYTE));
        memcpy((BYTE *)(&(ip->i.pcol)),&tempip[9],sizeof(BYTE));
        memcpy((BYTE *)(&(ip->i.check)),&tempip[10],sizeof(WORD));
        memcpy((BYTE *)(&(ip->i.sip)),&tempip[12],sizeof(LWORD));
        memcpy((BYTE *)(&(ip->i.dip)),&tempip[16],sizeof(LWORD));
//-----------------------------------------------------------------------
        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;
            {                               // ..delete them, move data down 
                memmove(&tempip[20], &tempip[20+hlen-IPHDRLEN], len);
                dlen -= hlen-IPHDRLEN;
            }
            memcpy((BYTE *)(&(ip->data)),&tempip[20],dlen);
            if ((ip->i.frags & 0x3fff)!=0)  /* If a fragment.. */
                dlen = defrag_ip(ip, dlen); /* ..call defragmenter */
        }
        else if (netdebug)
            Uart_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;
    BYTE  *tempip;
    BYTE  *tempip2;

    //ip = getframe_datap(gfp);           /* Get pointer to IP datagram */
    ip=&ipkt;
    tempip=getframe_datap(gfp);
    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)-IPHDRLEN) & 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 + IPHDRLEN + 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 */
        tempip2= (BYTE*)((BYTE*)sfp+sizeof(GENHDR)+fhlen);
        //memmove(ip2->data, &ip->data[oset], dlen-len);  /* Copy data 1st->2nd */
        memmove(&tempip2[20],&tempip[20],dlen-len);
        
        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+(IPHDRLEN>>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 + IPHDRLEN;         /* Data length */
    swap_ip(gfp);                       /* Do byte-swaps (for checksum) */
    ip->i.check = 0;                    /* Clear checksum */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产色综合久久不卡电影 | 国产午夜精品久久久久久免费视 | 一区二区三区成人| 欧美国产精品一区二区三区| 精品美女在线播放| 欧美一区二区视频在线观看2020| 91高清在线观看| 在线观看亚洲精品视频| 在线观看视频一区| 欧洲av在线精品| 色天天综合久久久久综合片| 91原创在线视频| 欧美伊人久久大香线蕉综合69| 色系网站成人免费| 欧洲激情一区二区| 欧美高清视频在线高清观看mv色露露十八 | 欧美日韩一区在线| 欧美日韩高清一区二区| 欧美调教femdomvk| 91精品国产色综合久久ai换脸| 91精品国产入口| 久久毛片高清国产| 国产精品不卡在线观看| 亚洲黄一区二区三区| 亚洲福中文字幕伊人影院| 视频一区欧美日韩| 国产乱妇无码大片在线观看| 国产夫妻精品视频| 成+人+亚洲+综合天堂| 在线观看日韩精品| 日韩一区二区在线观看视频播放| 日韩欧美一区在线观看| 日本一区二区三区四区| 一区二区不卡在线视频 午夜欧美不卡在| 一区二区三区在线视频观看 | 国产精品福利在线播放| 亚洲成人综合视频| 国产91精品一区二区麻豆网站 | 国产福利91精品| 色嗨嗨av一区二区三区| 精品久久人人做人人爰| 亚洲免费在线电影| 国产麻豆精品久久一二三| 日本福利一区二区| 久久综合丝袜日本网| 一区二区在线观看免费视频播放| 日韩国产在线观看一区| 99久久精品国产精品久久| 日韩三级视频在线观看| 亚洲欧美区自拍先锋| 久久国产三级精品| 欧美美女视频在线观看| 日本一区二区三区免费乱视频| 亚洲成人自拍偷拍| 色偷偷成人一区二区三区91| 国产视频不卡一区| 精品中文字幕一区二区| 精品视频一区二区三区免费| 亚洲视频一二三区| 国产91丝袜在线18| 国产偷国产偷亚洲高清人白洁| 日韩av不卡在线观看| 91激情五月电影| 国产精品卡一卡二卡三| 成人黄色免费短视频| 久久久久久久久久电影| 麻豆免费看一区二区三区| 欧美久久久一区| 亚洲大片精品永久免费| 欧美日韩和欧美的一区二区| 亚洲激情六月丁香| 欧美主播一区二区三区美女| 亚洲乱码国产乱码精品精小说| 成人av第一页| 中文字幕一区二区三区不卡在线| 国产不卡免费视频| 国产精品入口麻豆原神| 高清免费成人av| 国产欧美日韩在线视频| 丁香婷婷综合五月| 中文在线一区二区| 99久久综合色| 亚洲男人的天堂在线观看| 色综合久久中文字幕| 一二三四社区欧美黄| 日本精品一区二区三区高清| 一区二区三区在线看| 欧美午夜精品免费| 秋霞国产午夜精品免费视频| 日韩一区二区三区四区| 韩国午夜理伦三级不卡影院| 久久亚洲影视婷婷| 成人av一区二区三区| 亚洲欧美电影院| 欧美绝品在线观看成人午夜影视| 奇米精品一区二区三区四区| 欧美精品一区二区蜜臀亚洲| 国产伦精品一区二区三区视频青涩| 国产三级精品三级在线专区| 91免费精品国自产拍在线不卡| 亚洲一区二区黄色| 国产网红主播福利一区二区| 波多野结衣中文字幕一区二区三区| 亚洲天堂福利av| 欧美一区二区三区成人| 国产激情精品久久久第一区二区| 国产精品国产三级国产| 91麻豆精品91久久久久同性| 激情综合网天天干| 一区二区三区在线视频观看58 | 极品美女销魂一区二区三区| 日韩毛片视频在线看| 欧美一级淫片007| 风间由美中文字幕在线看视频国产欧美| 中文字幕在线观看不卡视频| 欧美精品一卡两卡| www.在线成人| 人人狠狠综合久久亚洲| 中文字幕一区av| 欧美一区二区三级| 色哟哟亚洲精品| 国产成人综合在线观看| 日韩高清中文字幕一区| 中文字幕一区二区5566日韩| 亚洲精品在线观| 欧美日韩大陆在线| 91麻豆福利精品推荐| 国产一区三区三区| 日日夜夜免费精品| 中文字幕日韩一区二区| 精品久久久久av影院| 欧美日韩国产系列| 91丝袜高跟美女视频| 国产在线国偷精品免费看| 亚洲成a人v欧美综合天堂| 亚洲色图在线看| 国产农村妇女毛片精品久久麻豆 | 国产精品自在在线| 日韩福利视频网| 亚洲一区日韩精品中文字幕| 欧美激情自拍偷拍| 久久综合成人精品亚洲另类欧美 | 成人一区二区三区视频| 国产在线不卡一区| 久久福利视频一区二区| 五月天激情综合网| 亚洲一卡二卡三卡四卡无卡久久 | 久久亚洲捆绑美女| 精品国产乱码久久久久久久久| 欧美日韩精品一区二区三区四区| 色婷婷精品久久二区二区蜜臀av | 4438x亚洲最大成人网| 91成人免费在线| 欧美影片第一页| 欧美日韩国产中文| 日韩女优视频免费观看| 日韩欧美在线观看一区二区三区| 在线综合+亚洲+欧美中文字幕| 欧美无砖专区一中文字| 欧美精品久久99| 制服丝袜中文字幕一区| 欧美videossexotv100| 26uuu国产日韩综合| 久久久另类综合| 欧美国产激情一区二区三区蜜月| 久久久久久99久久久精品网站| 欧美激情一区三区| 综合在线观看色| 亚洲一区二区三区在线播放| 亚瑟在线精品视频| 狠狠色丁香婷婷综合| 成人一级黄色片| 色视频欧美一区二区三区| 欧美色精品天天在线观看视频| 日韩一区二区精品葵司在线| 久久美女艺术照精彩视频福利播放| 国产精品入口麻豆原神| 亚洲综合精品自拍| 美女视频黄a大片欧美| 国产成a人亚洲| 欧美日韩一级二级三级| 国产亲近乱来精品视频| 亚洲国产日韩在线一区模特| 青青草97国产精品免费观看 | 天堂蜜桃91精品| 国产激情精品久久久第一区二区| 91一区二区三区在线观看| 在线不卡中文字幕播放| 久久精品夜色噜噜亚洲aⅴ| 亚洲精品免费一二三区| 日本欧美久久久久免费播放网| 国产一区二区免费看| 色综合久久88色综合天天6 | 国产精品人成在线观看免费| 亚洲与欧洲av电影| 国产成人99久久亚洲综合精品| 欧美另类久久久品| 中文字幕视频一区二区三区久| 麻豆精品一区二区综合av| 91视频在线看|