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

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

?? router.c

?? 嵌入式小型TCPIP協議棧
?? C
字號:
/* Router utility 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.01 JPB 21/1/00
** v0.02 JPB 25/1/00  Added IP routing
** v0.03 JPB 26/1/00  Added framestore
** v0.04 JPB 27/1/00  Added SLIP support
** v0.05 JPB 24/2/00 Changed keyscan to ESC or ctrl-C
** v0.06 JPB 23/3/00  Used upcall pointers in TCP.C
** v0.07 JPB 3/7/00   Revised header for book CD
*/

#define VERSION "0.07"

#include <stdio.h>
#include <ctype.h>
#include <stdlib.h>
#include <string.h>
#include <conio.h>
#include <signal.h>

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

#define CFGFILE     "router.cfg"    /* Default config filename */
#define CFGEXT      ".cfg"          /* Default config extension */
#define MAXNETCFG   40              /* Max length of a net config string */
#define MAXREMS     8               /* Size of remote node address cache */

/* The 'frame buffers' store IP datagrams which can't be sent because the
** destination hasn't been ARPed yet. */
#define NFRAMES     4               /* Number of network frame buffers */
GENFRAME framestore[NFRAMES];       /* Frames for network Tx/Rx */
int frameidx;                       /* Index number of currently-used frame */

/* The 'local nodes' have the IP addresses etc. of each network interface */
NODE locnodes[MAXNETS];             /* My local node addrs for each net */
int nnets;                          /* Number of nets in use */

/* The 'remote node' store is an ARP cache, retaining recently accessed nodes */
NODE remnodes[MAXREMS];             /* Cache of remote node addresses */
int remidx;                         /* Index number of latest entry */

char cfgfile[MAXPATH+5]=CFGFILE;    /* Config filename */
char netcfg[MAXNETCFG+1]="??";      /* Network config string */
extern BYTE bcast[MACLEN];          /* Broadcast MAC (Ethernet) addr */
extern int netdebug;                /* Flag to enable net packet display */
int breakflag;                      /* Flag to indicate ctrl-break pressed */

extern NODE *(*get_locnode_n)(int n);   /* Upcall to get local node */

/* Private prototypes */
WORD read_netconfig_n(char *fname, int n, NODE *np);
void do_transmit(GENFRAME *gfp);
void do_receive(void);
void do_arp(GENFRAME *gfp, NODE *locp);
void do_icmp(GENFRAME *gfp, int rxlen, NODE *locp);
void do_poll(void);
NODE *find_subnet(NODE *destp);
void add_cache(NODE *np);
int lookup_cache(NODE *np);
void disp_usage(void);
NODE *locnode_n(int n);
void break_handler(int sig);

int main(int argc, char *argv[])
{
    int n, args=0, err=0;
    char *p, temps[20];
    WORD dt;
    NODE *np;

    printf("ROUTER v" VERSION "\n");            /* Sign on */
    get_locnode_n = locnode_n;                  /* Set upcall func ptr */
    signal(SIGINT, break_handler);              /* Trap ctrl-C */
    while (argc > ++args)                       /* Process command-line args */
    {
        if (argv[args][0]=='-')
        {
            switch (toupper(argv[args][1]))
            {
            case 'C':                           /* -C: config filename */
                strncpy(cfgfile, argv[++args], MAXPATH);
                if ((p=strrchr(cfgfile, '.'))==0 || !isalpha(*(p+1)))
                    strcat(cfgfile, CFGEXT);
                break;
            case 'V':                           /* -V: verbose (debug) mode */
                netdebug = 1;
                break;
            default:
                err = 1;
            }
        }
    }
    if (err)                                    /* Erorr: display usage */
    {
        disp_usage();
        exit(1);
    }
    while (nnets<MAXNETS &&                     /* Load net drivers */
           (dt=read_netconfig_n(cfgfile, nnets, &locnodes[nnets]))!=0)
    {
        np = &locnodes[nnets++];                /* Print net addresses etc. */
        np->dtype = dt;
        printf ("Net %u %-15s ", nnets, ipstr(np->ip, temps));
        printf ("mask %-15s ", ipstr(np->mask, temps));
        if (dt & DTYPE_ETHER)
            printf("Ethernet %s\n", ethstr(np->mac, temps));
        else
            printf("SLIP\n");
    }
    if (nnets < 2)
        printf("Insufficient networks for router\n");
    else
    {
        printf("Press ESC or ctrl-C to exit\n");
        while (!breakflag)                      /* Main loop.. */
        {
            do_receive();                       /* ..handle Rx packets */
            do_poll();                          /* ..keep net drivers alive */
            if (kbhit())                        /* If key hit, check for ESC */
                breakflag = getch()==0x1b;
        }
        for (n=0; n<nnets; n++)
            close_net(locnodes[n].dtype);       /* Shut down net drivers */
    }
    return(0);
}

/* Read nth network config item (n=0 for first) to get IP addresses and netmasks
** Return driver type, 0 if error */
WORD read_netconfig_n(char *fname, int n, NODE *np)
{
    char temps[31];
    WORD dtype=0;
    BYTE b;

    if (read_cfgstr_n(fname, n, "net", netcfg, MAXNETCFG))
    {
        if (!read_cfgstr_n(fname, n, "ip", temps, 30) ||
                 (np->ip=atoip(temps))==0)          /* Get IP address */
            printf("No IP address for net %u\n", n);
        else if (!(dtype = open_net(netcfg)))       /* Open net driver */
            printf("Can't open net %u driver '%s'\n", n, netcfg);
        else
        {
            memcpy(np->mac, ether_addr(dtype), MACLEN);
            b = (BYTE)(np->ip >> 24);
            if (read_cfgstr_n(fname, n, "mask", temps, 30))
                np->mask = atoip(temps);            /* Get netmask */
            else
                np->mask = b<128 ? 0xff000000L: b<192 ? 0xffff0000L:0xffffff00L;
            if (read_cfgstr_n(fname, n, "gate", temps, 30))
                np->gate = atoip(temps);            /* Get gateway IP addr */
            else
                np->gate = 0;
        }
    }
    return(dtype);
}

/* Check for incoming packets, send response if required */
void do_receive(void)
{
    int txlen;
    WORD rxlen;
    NODE *locp, srce, dest;
    IPKT *ip, *ip2;
    GENFRAME *gfp;

    gfp = &framestore[frameidx];                    /* Ptr to current frame */
    gfp->g.dtype = 0;                               /* Has any net driver.. */
    if ((rxlen=get_frame(gfp)) > 0)                 /* ..got incoming frame? */
    {
        locp = &locnodes[gfp->g.dtype&NETNUM_MASK]; /* Get my local address */
        if (is_arp(gfp, rxlen))                     /* If ARP.. */
        {
            do_arp(gfp, locp);                      /* ..handle it */
        }
        else if ((rxlen=is_ip(gfp, rxlen))!=0 &&    /* If IP datagram.. */
                 !is_bcast(gfp))                    /* ..but not broadcast.. */
        {
            ip = getframe_datap(gfp);               /* If ICMP  pkt to me.. */
            if (ip->i.dip==locp->ip && (rxlen=is_icmp(ip, rxlen))!=0)
            {
                do_icmp(gfp, rxlen, locp);          /* Send ICMP response */
            }
            else                                    /* Datagram needs routing */
            {
                getip_srce(gfp, &srce);             /* Get source addr */
                add_cache(&srce);                   /* ..and add to cache */
                getip_dest(gfp, &dest);             /* Get dest addr */
                gfp->g.len = gfp->g.fragoff = 0;
                if ((locp=find_subnet(&dest))!=0)   /* Find correct subnet.. */
                {
                    gfp->g.dtype = locp->dtype;     /* ..and its driver type */
                    ip2 = getframe_datap(gfp);      /* Get datagram posn */
                    if (ip != ip2)                  /* If new posn in frame.. */
                        memmove(ip2, ip, rxlen+sizeof(IPHDR));  /* ..move it */
                    ip = ip2;
                    if (locp->dtype & DTYPE_SLIP || /* If SLIP.. */
                        lookup_cache(&dest))        /* ..or dest in cache */
                    {                               /* Make IP datagram */
                        txlen = make_ip(gfp, &srce, &dest, ip->i.pcol, rxlen);
                        put_frame(gfp, txlen);      /* ..and send it */
                    }
                    else
                    {
                        gfp->g.len = rxlen;         /* Save current frame */
                        frameidx = (frameidx+1) % NFRAMES;
                        gfp = &framestore[frameidx];
                        gfp->g.dtype = locp->dtype; /* Broadcast ARP request */
                        memcpy(dest.mac, bcast, MACLEN);
                        txlen = make_arp(gfp, locp, &dest, ARPREQ);
                        put_frame(gfp, txlen);      /* Send packet */
                    }
                }
            }
        }
    }
}

/* Handle an incoming ARP packet, given local node address */
void do_arp(GENFRAME *gfp, NODE *locp)
{
    ARPKT *arp;
    NODE rem, srce;
    IPKT *ip;
    int txlen, i, n;

    arp = getframe_datap(gfp);
    if (arp->dip == locp->ip)               /* ARP intended for me? */
    {
        rem.ip = arp->sip;                  /* Get remote (source) addrs */
        memcpy(rem.mac, arp->smac, MACLEN);
        rem.dtype = gfp->g.dtype;           /* ..and driver type */
        if (arp->op == ARPREQ)              /* If ARP request.. */
        {                                   /* ..make ARP response */
            txlen = make_arp(gfp, locp, &rem, ARPRESP);
            put_frame(gfp, txlen);          /* ..send packet */
        }
        else if (arp->op == ARPRESP)        /* If ARP response.. */
        {
            add_cache(&rem);                /* ..add to cache */
            for (n=0, i=frameidx; n<NFRAMES-1; n++)
            {                               /* Search framestore */
                gfp = &framestore[i=(i+1)%NFRAMES];
                ip = getframe_datap(gfp);
                if (rem.ip == ip->i.dip)    /* If matching IP addr.. */
                {
                    gfp->g.dtype = rem.dtype;       /* ..make datagram.. */
                    srce = locnodes[rem.dtype & NETNUM_MASK];
                    srce.ip = ip->i.sip;
                    txlen = make_ip(gfp, &srce, &rem, ip->i.pcol, gfp->g.len);
                    put_frame(gfp, txlen);          /* ..and send it */
                    ip->i.dip = 0;
                }
            }
        }
    }
}

/* Handle an incoming ICMP packet, given length and local node address */
void do_icmp(GENFRAME *gfp, int rxlen, NODE *locp)
{
    ICMPKT *icmp;
    NODE rem;
    int len, txlen;

    icmp = getframe_datap(gfp);         /* Get pointer to packet */
    getip_srce(gfp, &rem);              /* Get remote addrs */
    if (icmp->c.type==ICREQ)            /* Echo request? */
    {
        len = (WORD)maxi(rxlen, 0);     /* Make response */
        txlen = make_icmp(gfp, locp, &rem, ICREP, icmp->c.code, (WORD)len);
        put_frame(gfp, txlen);          /* Send packet */
    }
}

/* Poll the network interface to keep it alive */
void do_poll(void)
{
    int n;

    for (n=0; n<nnets; n++)
        poll_net(locnodes[n].dtype);
}

/* Find the local node, given a remote node that should be on the same subnet
** Return pointer to local node, or 0 if remote is unreachable */
NODE *find_subnet(NODE *destp)
{
    int n=0, ok=0;

    while (n<nnets && !(ok=on_subnet(destp->ip, &locnodes[n])))
        n++;
    return(ok ? &locnodes[n] : 0);
}

/* Add a node to the ARP cache */
void add_cache(NODE *np)
{
    char temps[21];

    if (!lookup_cache(np))
    {
        remnodes[remidx] = *np;
        remidx = (remidx+1) % MAXREMS;
        if (netdebug)
            printf ("Adding %s to ARP cache\n", ipstr(np->ip, temps));
    }
}

/* Look up a node in the ARP cache. If found, fill in MAC addr, return non-0 */
int lookup_cache(NODE *np)
{
    int i=remidx, n=MAXREMS, ok=0;

    while (!(ok=remnodes[i=(i-1)%MAXREMS].ip == np->ip) && n>0)
        n--;
    if (ok)
        *np = remnodes[i];
    return(ok);
}

/* Return ptr to local node 'n' (n=0 for first), return 0 if doesn't exist
** Used by IP functions to get my netmask & gateway addresses */
NODE *locnode_n(int n)
{
    return(n<nnets ? &locnodes[n] : 0);
}

/* Display usage help */
void disp_usage(void)
{
    printf("Usage:    ROUTER [options]\n");
    printf("Options:  -c name   Config filename (default %s)\n", cfgfile);
    printf("          -v        Verbose mode (displays network packets)\n");
    printf("Example:  ROUTER -v -c test.cfg\n");
}

/* Ctrl-break handler: set flag and return */
void break_handler(int sig)
{
    breakflag = sig;
}

/* EOF */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国内精品久久久久影院色| 日韩欧美一区二区三区在线| 在线观看91视频| 久久亚洲综合色| 亚洲成人动漫一区| 99re8在线精品视频免费播放| 91精品婷婷国产综合久久性色 | 国产伦精品一区二区三区在线观看| 成人av网站在线观看免费| 欧美大片免费久久精品三p| 伊人色综合久久天天| 成人性视频网站| 久久婷婷色综合| 国模少妇一区二区三区| 51久久夜色精品国产麻豆| 夜夜精品浪潮av一区二区三区| 国产福利91精品| 精品欧美一区二区三区精品久久| 亚洲小少妇裸体bbw| 一本大道综合伊人精品热热| 亚洲欧美在线视频| 成人黄页在线观看| 国产精品久久久久天堂| 国产成人在线免费| 久久精品欧美一区二区三区麻豆| 精品中文字幕一区二区| 欧美v国产在线一区二区三区| 婷婷六月综合亚洲| 欧美精三区欧美精三区| 日韩中文字幕区一区有砖一区| 色综合久久88色综合天天| 亚洲精选免费视频| 一本到不卡免费一区二区| 亚洲精品精品亚洲| 日韩亚洲欧美成人一区| 婷婷综合另类小说色区| 制服丝袜av成人在线看| 男女激情视频一区| 精品免费国产一区二区三区四区| 另类小说一区二区三区| 精品国产亚洲一区二区三区在线观看| 日本aⅴ亚洲精品中文乱码| 日韩免费在线观看| 国产福利91精品一区二区三区| 国产日韩欧美一区二区三区综合 | www.av精品| 亚洲欧美偷拍卡通变态| 日本高清无吗v一区| 亚洲第一搞黄网站| 日韩免费性生活视频播放| 国产成人精品在线看| 自拍偷拍国产亚洲| 欧美精品aⅴ在线视频| 美脚の诱脚舐め脚责91| 欧美国产日韩一二三区| 在线观看日韩电影| 激情久久五月天| 亚洲人成精品久久久久久| 欧美另类变人与禽xxxxx| 九九九久久久精品| 一区二区三区日韩欧美精品| 91精品国产手机| 成人av午夜电影| 蜜臀久久99精品久久久久宅男| 久久影院电视剧免费观看| 91麻豆精品秘密| 久久精品国产一区二区三| 亚洲天堂福利av| 精品久久久久久无| 在线视频国内自拍亚洲视频| 国产在线一区二区综合免费视频| 综合久久给合久久狠狠狠97色| 制服丝袜亚洲网站| 不卡视频一二三四| 美女看a上一区| 亚洲制服丝袜一区| 国产日韩精品一区| 欧美一级日韩免费不卡| 91麻豆免费视频| 韩国v欧美v日本v亚洲v| 性感美女久久精品| 亚洲色图第一区| 欧美国产日韩精品免费观看| 91精品国产一区二区三区蜜臀| 99久久久无码国产精品| 久久66热偷产精品| 日韩精品色哟哟| 亚洲靠逼com| 一区在线播放视频| 日本一区二区三区在线不卡| 亚洲国产精品成人综合| 91精品国产欧美一区二区成人 | 国产一区二区在线视频| 亚洲一区二区三区四区在线观看| 中文字幕成人av| 久久免费视频色| 欧美成人伊人久久综合网| 欧美日韩精品一区二区在线播放| 99国产精品视频免费观看| 国产91精品一区二区麻豆亚洲| 香蕉乱码成人久久天堂爱免费| 亚洲欧洲综合另类在线| 国产精品乱人伦| 国产精品成人一区二区艾草| 国产日产欧美精品一区二区三区| 精品粉嫩aⅴ一区二区三区四区| 欧美一区二区三区婷婷月色| 欧美剧情片在线观看| 欧美日韩一区在线观看| 欧洲av在线精品| 欧洲激情一区二区| 欧洲一区在线观看| 欧美中文字幕一二三区视频| 在线看不卡av| 欧美午夜一区二区三区 | 日韩和欧美的一区| 天使萌一区二区三区免费观看| 亚洲国产精品自拍| 天天影视网天天综合色在线播放| 亚洲第一狼人社区| 日韩综合一区二区| 精品在线观看免费| 国产成人午夜精品5599| 成人综合激情网| 色哟哟一区二区在线观看| 91极品视觉盛宴| 欧美久久高跟鞋激| 2019国产精品| 国产精品另类一区| 亚洲一区二区三区四区五区黄| 婷婷亚洲久悠悠色悠在线播放| 日韩国产精品久久| 国产精品 日产精品 欧美精品| 国产成人av电影在线观看| 91亚洲精品久久久蜜桃网站 | 五月天亚洲婷婷| 国内成+人亚洲+欧美+综合在线| 国产99久久久国产精品免费看 | av毛片久久久久**hd| 日本韩国一区二区三区| 欧美一卡2卡三卡4卡5免费| 精品国内片67194| 国产精品久久久久桃色tv| 亚洲午夜激情网页| 国产美女精品人人做人人爽| 99国产精品久久久久久久久久| 色噜噜狠狠成人中文综合| 欧美一区永久视频免费观看| 日本一区二区三区国色天香| 一区二区国产视频| 国产制服丝袜一区| 欧美亚洲尤物久久| 久久网站最新地址| 性感美女极品91精品| 国产精品99久久久久久有的能看| 97超碰欧美中文字幕| 欧美一级片在线观看| 国产精品免费视频观看| 日日摸夜夜添夜夜添精品视频| 国产精品18久久久久久vr| 欧美性xxxxxx少妇| 国产女人18毛片水真多成人如厕| 亚洲午夜激情av| 国产欧美日韩不卡| 天堂va蜜桃一区二区三区漫画版| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 亚洲欧洲美洲综合色网| 日本中文字幕一区二区视频 | 99久久免费视频.com| 日韩精品中文字幕在线一区| 亚洲欧美激情小说另类| 国产一区二区毛片| 日韩精品中文字幕一区二区三区| 亚洲免费电影在线| 国产99久久久国产精品潘金网站| 91麻豆精品国产综合久久久久久| 亚洲精品国产第一综合99久久| 韩国理伦片一区二区三区在线播放| 欧美亚洲一区三区| 亚洲色图另类专区| av电影在线观看不卡| 久久久久国产精品麻豆| 麻豆精品视频在线观看免费| 欧美猛男男办公室激情| 亚洲综合色区另类av| 99精品热视频| 中文字幕不卡在线| 成人丝袜高跟foot| 中文字幕欧美激情一区| 国产麻豆精品95视频| 2020国产精品自拍| 国产乱人伦偷精品视频不卡| 2021中文字幕一区亚洲| 国产一区视频导航| 26uuu国产日韩综合| 国产成人综合精品三级| 国产欧美日韩不卡免费| 国产91精品露脸国语对白| 中文字幕精品在线不卡| 大美女一区二区三区|