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

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

?? aodv.cc

?? 在Linux下做的QuadTree的程序
?? CC
?? 第 1 頁 / 共 2 頁
字號:
voidAODV::recvAODV(Packet *p){        struct hdr_ip *ih = HDR_IP(p);        struct hdr_aodv *ah = HDR_AODV(p);        assert(ih->sport_ == RT_PORT);        assert(ih->dport_ == RT_PORT);        /*         * Incoming Packets.         */        switch(ah->ah_type) {        case AODVTYPE_HELLO:                recvHello(p);                break;        case AODVTYPE_RREQ:                recvRequest(p);                break;        case AODVTYPE_RREP:        case AODVTYPE_UREP:                recvReply(p);                break;        default:                fprintf(stderr, "Invalid AODV type (%x)\n", ah->ah_type);                exit(1);        }}voidAODV::recvRequest(Packet *p){        struct hdr_ip *ih = HDR_IP(p);        struct hdr_aodv_request *rq = HDR_AODV_REQUEST(p);        rt_entry *rt;        /*         * Drop if:         *      - I'm the source         *      - I recently heard this request.         */        if(rq->rq_src == index) {#ifdef DEBUG                fprintf(stderr, "%s: got my own REQUEST\n", __FUNCTION__);#endif                Packet::free(p);                return;        }         if(id_lookup(rq->rq_src) >= rq->rq_bcast_id) {#ifdef DEBUG                fprintf(stderr, "%s: discarding request\n", __FUNCTION__);#endif                Packet::free(p);                return;        }        /*         * Cache the ID         */        id_insert(rq->rq_src, rq->rq_bcast_id);        rt = rtable.rt_lookup(rq->rq_dst);        /*          * We are either going to forward the REQUEST or generate a         * REPLY.  Make sure that the REVERSE route is in the Route         * Cache.         */        {                 rt_entry *rt0;                rt0 = rtable.rt_lookup(rq->rq_src);                if(rt0 == 0) {                        rt0 = rtable.rt_add(rq->rq_src);                }                /*                 * XXX - Am I doing the right thing if a route already exists?                 */                rt0->rt_seqno = rq->rq_src_seqno;                rt0->rt_nexthop = ih->src_;                rt0->rt_expire = CURRENT_TIME +                        (rt && rt->rt_seqno > rq->rq_dst_seqno ?                         ACTIVE_ROUTE_TIMEOUT : REV_ROUTE_LIFE);                rt0->rt_hops = rq->rq_hop_count;                rt0->rt_flags = RTF_UP;        }        /*         * Send a Route Reply.         */        if(rq->rq_dst == index) {#ifdef DEBUG                fprintf(stderr, "%d - %s: destination sending reply\n",                        index, __FUNCTION__);#endif                /*                 * Actually, this is wrong and skews the route lengths                 * used to the "high" side since Requests that take                 * longer to reach the destination are replied to with                 * a higher sequence number. 04/29/98 - josh                 */                seqno += 1;                     // Just to be safe...                sendReply(rq->rq_src,           // IP Destination                          1,                    // Hop Count                          index,                // Dest IP Address                          seqno,                // Dest Sequence Num                          MY_ROUTE_TIMEOUT,     // Lifetime                          rq->rq_timestamp);    // timestamp                Packet::free(p);        }        else if(rt && rt->rt_seqno > rq->rq_dst_seqno) {                sendReply(rq->rq_src,                          rt->rt_hops + 1,                          rq->rq_dst,                          rt->rt_seqno,                          (u_int32_t) (rt->rt_expire - CURRENT_TIME),                          rq->rq_timestamp);                Packet::free(p);        }        /*         * Forward the  Route Request         */        else {                ih->dst_ = IP_BROADCAST;                ih->src_ = index;                rq->rq_hop_count += 1;                forward((rt_entry*) 0, p, 1 /* Jitter */);        }}#ifdef COMMENT_ONLYXXX - The forwarding of Route Replies as [not] specified in the draft,completely breaks if normal IP-forwarding is used because you need toknow the IP Address of the node that you received the Reply from inorder to setup the "forward" route.Rather than change the packet format as specified in the draft, I puta "previous hop" field in the Route Reply so we know who sent it tous.  -jorjeta#endifvoidAODV::recvReply(Packet *p){        struct hdr_cmn *ch = HDR_CMN(p);        struct hdr_ip *ih = HDR_IP(p);        struct hdr_aodv_reply *rp = HDR_AODV_REPLY(p);        rt_entry *rt;#ifdef DEBUG        fprintf(stderr, "%d - %s: received a REPLY\n", index, __FUNCTION__);#endif        /*         *  Got a reply so reset any state the "count" of Route Request         *  packets sent.         */        if((rt = rtable.rt_lookup(rp->rp_dst))) {                rt->rt_req_cnt = 0;                rt->rt_req_timeout = 0.0;        }        /*         *  Handle "Route Errors" separately...         */        if(rp->rp_hop_count == INFINITY) {                recvTriggeredReply(p);                return;        }        /*         *  If I don't have a route to this host...         */        if(rt == 0) {                rt = rtable.rt_add(rp->rp_dst);        }        /*         * Add a forward route table entry...         */        if((rt->rt_flags & RTF_UP) == 0 ||              // better route           (rt->rt_seqno < rp->rp_dst_seqno &&          // shorter route            rt->rt_hops > rp->rp_hop_count)) {                rt->rt_seqno = rp->rp_dst_seqno;                rt->rt_nexthop = ch->prev_hop_;                rt->rt_expire = rp->rp_lifetime;                rt->rt_hops = rp->rp_hop_count;                rt->rt_flags = RTF_UP;#ifdef AODV_LINK_LAYER_DETECTION                rt->rt_errors = 0;                rt->rt_error_time = 0.0;#endif        }#ifdef DEBUG        else if(ih->dst_ == index) {                fprintf(stderr,                        "(%2d) %2d - Extra Route Reply, dst: %2d, turnaround: %f, hops: %d\n",                        ++extra_route_reply,                        index,                        rp->rp_dst,                        CURRENT_TIME - rp->rp_timestamp,                        rt->rt_hops);        }#endif        /*         *  Reply was for me, discard it.         */        if(ih->dst_ == index) {                Packet::free(p);        }        /*         * Forward the Route Reply.         */        else {                rt_entry *rt0 = rtable.rt_lookup(ih->dst_);                if(rt0 && (rt0->rt_flags & RTF_UP)) {                        rp->rp_hop_count += 1;                        forward(rt0, p, 0 /* No Jitter */);                }                else {#ifdef DEBUG                        fprintf(stderr, "%s: droping Route Reply\n",                                __FUNCTION__);#endif                        drop(p, DROP_RTR_NO_ROUTE);                }        }        /*         * Send all packets queued for the destination.         * XXX - observe the "second" use of p.         */        while((p = rqueue.deque(rt->rt_dst))) {                if(rt->rt_flags & RTF_UP) {                        forward(rt, p, 1 /* Jitter */);                }                else {                        drop(p, DROP_RTR_NO_ROUTE);                }        }}voidAODV::recvTriggeredReply(Packet *p){        struct hdr_ip *ih = HDR_IP(p);        struct hdr_aodv_reply *rp = HDR_AODV_REPLY(p);        rt_entry *rt = rtable.rt_lookup(rp->rp_dst);        if(rt && (rt->rt_flags & RTF_UP)) {                /*                 *  I belive the INFINITY metric if this node has a larger                 *  sequence number or if the node is my next hop (since                 *  he won't forward packets for me anyways).                 */                if(rt->rt_seqno <= rp->rp_dst_seqno ||                    rt->rt_nexthop == ih->src_) {                        /*                         *  XXX - This could result in getting a lower sequence                         *  number, but I don't think that this matters.                         */                        rt->rt_seqno = rp->rp_dst_seqno;                        rt_down(rt);                }        }        Packet::free(p);}voidAODV::recvHello(Packet *p){        struct hdr_aodv_reply *rp = HDR_AODV_REPLY(p);        Neighbor *nb;        /*         *  XXX: I use a separate TYPE for hello messages rather than         *  a bastardized Route Reply.         */        nb = nb_lookup(rp->rp_dst);        if(nb == 0) {                nb_insert(rp->rp_dst);        }        else {                nb->nb_expire = CURRENT_TIME +                        (1.5 * ALLOWED_HELLO_LOSS * HELLO_INTERVAL);        }        Packet::free(p);}/* ======================================================================   Packet Transmission Routines   ===================================================================== */voidAODV::forward(rt_entry *rt, Packet *p, int jitter){        struct hdr_cmn *ch = HDR_CMN(p);        struct hdr_ip *ih = HDR_IP(p);        Neighbor *nb;        if(ih->ttl_ == 0) {#ifdef DEBUG                fprintf(stderr, "%s: calling drop()\n", __PRETTY_FUNCTION__);#endif                drop(p, DROP_RTR_TTL);                return;        }        /*         * Keep the "official" Neighbor List up-to-date.         */        if((nb = nb_lookup(ch->prev_hop_)) == 0) {                nb_insert(ch->prev_hop_);        }        if(rt) {                assert(rt->rt_flags & RTF_UP);                /*                 *  Need to maintain the per-route Neighbor List.  This is                 *  kept separate from the Neighbor list that is the list                 *  of ACTIVE neighbors.  I don't bother to expire these                 *  entries.                 */                if(rt->nb_lookup(ch->prev_hop_) == 0) {                        rt->nb_insert(ch->prev_hop_);                }                rt->rt_expire = CURRENT_TIME + ACTIVE_ROUTE_TIMEOUT;                ch->prev_hop_ = index;                ch->next_hop_ = rt->rt_nexthop;                ch->addr_type() = AF_INET;        }        else {                assert(ch->ptype() == PT_AODV);                assert(ih->dst_ == (nsaddr_t) IP_BROADCAST);                ch->addr_type() = AF_NONE;        }        if(jitter) {                /*                 *  Jitter the sending of broadcast packets by 10ms                 */                Scheduler::instance().schedule(target_, p,                                               0.01 * Random::uniform());        }        else {                target_->recv(p, (Handler*) 0);        }}voidAODV::sendRequest(nsaddr_t dst){        Packet *p = Packet::alloc();        struct hdr_cmn *ch = HDR_CMN(p);        struct hdr_ip *ih = HDR_IP(p);        struct hdr_aodv_request *rq = HDR_AODV_REQUEST(p);        rt_entry *rt = rtable.rt_lookup(dst);        assert(rt);        /*         *  Rate limit sending of Route Requests         */        if(rt->rt_req_cnt > RREQ_RETRIES ||           rt->rt_req_timeout > CURRENT_TIME) {#ifdef DEBUG                fprintf(stderr, "(%2d) - %2d can't send Request, dst: %d\n",                        ++limit_route_request, index, rt->rt_dst);#endif                return;        }#ifdef DEBUG        fprintf(stderr, "(%2d) - %2d sending Route Request, dst: %d\n",                ++route_request, index, rt->rt_dst);#endif        rt->rt_req_timeout = CURRENT_TIME + RREP_WAIT_TIME;        rt->rt_req_cnt += 1;        // ch->uid() = 0;        ch->ptype() = PT_AODV;        ch->size() = IP_HDR_LEN + sizeof(*rq);        ch->iface() = -2;        ch->error() = 0;        ch->addr_type() = AF_NONE;        ch->prev_hop_ = index;          // AODV hack        ih->src_ = index;        ih->dst_ = IP_BROADCAST;        ih->sport_ = RT_PORT;        ih->dport_ = RT_PORT;        ih->ttl_ = IP_DEF_TTL;        rq->rq_type = AODVTYPE_RREQ;        rq->rq_hop_count = 0;        rq->rq_bcast_id = bid++;        rq->rq_dst = dst;        rq->rq_dst_seqno = (rt ? rt->rt_seqno : 0);        rq->rq_src = index;        rq->rq_src_seqno = seqno;        rq->rq_timestamp = CURRENT_TIME;        target_->recv(p, (Handler*) 0);}voidAODV::sendReply(nsaddr_t ipdst, u_int32_t hop_count, nsaddr_t rpdst,                u_int32_t rpseq, u_int32_t lifetime, double timestamp){        Packet *p = Packet::alloc();        struct hdr_cmn *ch = HDR_CMN(p);        struct hdr_ip *ih = HDR_IP(p);        struct hdr_aodv_reply *rp = HDR_AODV_REPLY(p);        rt_entry *rt = rtable.rt_lookup(ipdst);        assert(rt);        // ch->uid() = 0;        ch->ptype() = PT_AODV;        ch->size() = IP_HDR_LEN + sizeof(*rp);        ch->iface() = -2;        ch->error() = 0;        ch->addr_type() = AF_INET;        ch->next_hop_ = rt->rt_nexthop;        ch->prev_hop_ = index;          // AODV hack        ih->src_ = index;        ih->dst_ = ipdst;        ih->sport_ = RT_PORT;        ih->dport_ = RT_PORT;        ih->ttl_ = IP_DEF_TTL;        rp->rp_type = AODVTYPE_RREP;        rp->rp_flags = 0x00;        rp->rp_hop_count = hop_count;        rp->rp_dst = rpdst;        rp->rp_dst_seqno = rpseq;        rp->rp_lifetime = lifetime;        rp->rp_timestamp = timestamp;        target_->recv(p, (Handler*) 0);     }voidAODV::sendTriggeredReply(nsaddr_t ipdst, nsaddr_t rpdst, u_int32_t rpseq){	// 08/28/98 - added this extra check	if(ipdst == 0 || ipdst == index) return;        Packet *p = Packet::alloc();        struct hdr_cmn *ch = HDR_CMN(p);        struct hdr_ip *ih = HDR_IP(p);        struct hdr_aodv_reply *rp = HDR_AODV_REPLY(p);        // ch->uid() = 0;        ch->ptype() = PT_AODV;        ch->size() = IP_HDR_LEN + sizeof(*rp);        ch->iface() = -2;        ch->error() = 0;        ch->addr_type() = AF_NONE;        ch->next_hop_ = 0;        ch->prev_hop_ = index;          // AODV hack        ih->src_ = index;        ih->dst_ = ipdst;        ih->sport_ = RT_PORT;        ih->dport_ = RT_PORT;        ih->ttl_ = 1;        rp->rp_type = AODVTYPE_UREP;        rp->rp_flags = 0x00;        rp->rp_hop_count = INFINITY;        rp->rp_dst = rpdst;        rp->rp_dst_seqno = rpseq;        rp->rp_lifetime = 0;            // XXX        target_->recv(p, (Handler*) 0);     }voidAODV::sendHello(){        Packet *p = Packet::alloc();        struct hdr_cmn *ch = HDR_CMN(p);        struct hdr_ip *ih = HDR_IP(p);        struct hdr_aodv_reply *rh = HDR_AODV_REPLY(p);        // ch->uid() = 0;        ch->ptype() = PT_AODV;        ch->size() = IP_HDR_LEN + sizeof(*rh);        ch->iface() = -2;        ch->error() = 0;        ch->addr_type() = AF_NONE;        ch->prev_hop_ = index;          // AODV hack        ih->src_ = index;        ih->dst_ = IP_BROADCAST;        ih->sport_ = RT_PORT;        ih->dport_ = RT_PORT;        ih->ttl_ = 1;        rh->rp_type = AODVTYPE_HELLO;        rh->rp_flags = 0x00;        rh->rp_hop_count = 0;        rh->rp_dst = index;        rh->rp_dst_seqno = seqno;        rh->rp_lifetime = (1 + ALLOWED_HELLO_LOSS) * HELLO_INTERVAL;        target_->recv(p, (Handler*) 0);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美在线三级电影| 久久久久久久久久久电影| 日韩三级视频在线看| 中文字幕不卡的av| 久久精品久久精品| 在线免费观看日本一区| 欧美激情一区在线| 青草国产精品久久久久久| 色婷婷久久久亚洲一区二区三区| 精品国产在天天线2019| 日韩高清一区在线| 欧美色综合网站| 亚洲色图欧美偷拍| 精品少妇一区二区三区视频免付费| 国产精品国产精品国产专区不蜜| 久久 天天综合| 91精品国产一区二区| 一区二区三区资源| 91农村精品一区二区在线| 欧美国产成人精品| 国产美女精品在线| 久久综合五月天婷婷伊人| 日本欧美一区二区三区乱码| 欧美日韩精品一二三区| 一级日本不卡的影视| 色婷婷激情综合| 亚洲日本在线天堂| 色婷婷久久综合| 亚洲精品视频免费观看| 在线一区二区三区| 一区二区高清在线| 欧美日韩在线免费视频| 亚洲国产日韩精品| 欧美日韩大陆在线| 日韩精品电影在线| 日韩欧美亚洲国产精品字幕久久久| 视频在线在亚洲| 欧美一区二区三区啪啪| 麻豆国产精品官网| 久久毛片高清国产| 成人免费黄色在线| 亚洲视频免费观看| 在线观看一区二区视频| 亚洲小说欧美激情另类| 7777精品伊人久久久大香线蕉完整版 | 本田岬高潮一区二区三区| 国产亚洲精品资源在线26u| 丰满少妇久久久久久久| 亚洲欧美日韩一区| 欧美日韩一区在线| 欧美aaaaa成人免费观看视频| 欧美成人精品1314www| 国产成人av一区二区三区在线| 国产精品久久久久久久久免费桃花 | 国产蜜臀av在线一区二区三区| 国产成人超碰人人澡人人澡| 亚洲欧美一区二区三区久本道91 | 日韩欧美中文字幕制服| 国产在线不卡一区| 亚洲人成7777| 欧美一级一区二区| 国产激情一区二区三区四区 | 一本大道久久a久久精二百| 亚洲成人精品在线观看| 精品国产凹凸成av人网站| 大白屁股一区二区视频| 亚洲一二三级电影| www激情久久| 日本高清免费不卡视频| 蜜桃视频在线一区| 综合激情成人伊人| 日韩三级精品电影久久久 | 另类综合日韩欧美亚洲| 中文字幕一区二区三区精华液| 欧美系列在线观看| 国产精品夜夜爽| 午夜伦欧美伦电影理论片| 久久嫩草精品久久久久| 在线精品视频一区二区三四| 国产一二精品视频| 天天av天天翘天天综合网| 国产目拍亚洲精品99久久精品| 欧美午夜片在线观看| 国产成人精品午夜视频免费| 亚洲777理论| 综合av第一页| 亚洲国产精品精华液ab| 日韩一卡二卡三卡国产欧美| 在线免费观看不卡av| 高清beeg欧美| 国产一区二区免费视频| 日韩和欧美的一区| 一区二区三区在线视频播放| 中文字幕欧美日韩一区| 久久在线观看免费| 欧美一区二区成人| 欧美日韩视频专区在线播放| 色又黄又爽网站www久久| 成人深夜视频在线观看| 国产另类ts人妖一区二区| 日本va欧美va精品发布| 亚欧色一区w666天堂| 亚洲欧美经典视频| 国产精品电影一区二区| 国产日韩综合av| 久久久亚洲午夜电影| 日韩美女一区二区三区四区| 最新国产精品久久精品| 久久午夜羞羞影院免费观看| 欧美mv日韩mv国产| 日韩欧美一区二区免费| 4438成人网| 69p69国产精品| 欧美一区二区精品| 日韩一二三区视频| 日韩免费看网站| 久久毛片高清国产| 国产亚洲成年网址在线观看| 久久先锋影音av鲁色资源网| 国产亚洲视频系列| 中文字幕成人av| 日韩一区有码在线| 亚洲一区在线看| 亚洲成人黄色小说| 日本成人在线视频网站| 激情综合网av| 高清在线观看日韩| 91日韩一区二区三区| 欧洲国内综合视频| 6080亚洲精品一区二区| 精品理论电影在线观看| 国产欧美日韩激情| 亚洲色大成网站www久久九九| 亚洲尤物在线视频观看| 日韩av高清在线观看| 狠狠色狠狠色综合日日91app| 精品成人一区二区三区四区| 欧美精品一区在线观看| 日本一区二区高清| 亚洲午夜在线电影| 九一九一国产精品| 粉嫩蜜臀av国产精品网站| 色猫猫国产区一区二在线视频| 日本大香伊一区二区三区| 欧美一区二区久久久| 国产精品水嫩水嫩| 亚洲午夜激情av| 国产一区二区在线影院| 91蜜桃传媒精品久久久一区二区 | av在线一区二区三区| 欧美日韩在线免费视频| 精品99久久久久久| 一区二区三区资源| 国产揄拍国内精品对白| 91久久线看在观草草青青| 欧美一区二区播放| 椎名由奈av一区二区三区| 日韩电影在线观看电影| 成人av在线网站| 欧美成人精品福利| 亚洲自拍偷拍综合| 国产乱色国产精品免费视频| 在线观看国产精品网站| 久久九九久久九九| 日日摸夜夜添夜夜添精品视频| 国产v综合v亚洲欧| 亚洲高清免费观看高清完整版在线观看 | 久久久久亚洲综合| 亚洲午夜激情av| 99国产精品国产精品毛片| 欧美成人a∨高清免费观看| 一区二区三区蜜桃网| 国产精品一二三四五| 欧美一级欧美一级在线播放| 亚洲精品国久久99热| 国产精品香蕉一区二区三区| 制服丝袜一区二区三区| 亚洲欧美日韩小说| 成人少妇影院yyyy| 久久久久久日产精品| 蜜臀av性久久久久蜜臀aⅴ| 欧美亚洲一区三区| 综合激情成人伊人| 成人av在线观| 国产精品免费视频一区| 国产揄拍国内精品对白| 日韩一级二级三级精品视频| 天天影视网天天综合色在线播放| 91福利在线导航| 亚洲精品欧美在线| jizzjizzjizz欧美| 国产精品国产馆在线真实露脸 | 日韩在线一区二区三区| 欧美性生活影院| 亚洲精品日韩综合观看成人91| 99精品在线观看视频| 国产精品久久久久国产精品日日| 高清在线不卡av| 国产精品久久久久影院色老大 | 欧美午夜一区二区|