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

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

?? modified aodv.cc

?? the code of Ad Hoc On-demand Distance Vector (AODV) routing protocol for mobile ad hoc networks
?? CC
?? 第 1 頁 / 共 3 頁
字號:
/*Copyright (c) 1997, 1998 Carnegie Mellon University.  All RightsReserved. Permission to use, copy, modify, and distribute thissoftware and its documentation is hereby granted (including forcommercial or for-profit use), provided that both the copyright notice and this permission notice appear in all copies of the software, derivative works, or modified versions, and any portions thereof, and that both notices appear in supporting documentation, and that credit is given to Carnegie Mellon University in all publications reporting on direct or indirect use of this code or its derivatives.ALL CODE, SOFTWARE, PROTOCOLS, AND ARCHITECTURES DEVELOPED BY THE CMUMONARCH PROJECT ARE EXPERIMENTAL AND ARE KNOWN TO HAVE BUGS, SOME OFWHICH MAY HAVE SERIOUS CONSEQUENCES. CARNEGIE MELLON PROVIDES THISSOFTWARE OR OTHER INTELLECTUAL PROPERTY IN ITS ``AS IS'' CONDITION,AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULARPURPOSE ARE DISCLAIMED. IN NO EVENT SHALL CARNEGIE MELLON UNIVERSITYBE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, ORCONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OFSUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; ORBUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCEOR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE ORINTELLECTUAL PROPERTY, EVEN IF ADVISED OF THE POSSIBILITY OF SUCHDAMAGE.Carnegie Mellon encourages (but does not require) users of thissoftware or intellectual property to return any improvements orextensions that they make, and to grant Carnegie Mellon the rights to redistribute these changes without encumbrance.The AODV code developed by the CMU/MONARCH group was optimized and tuned by Samir Das and Mahesh Marina, University of Cincinnati. The work was partially done in Sun Microsystems. Modified for gratuitous replies by Anant Utgikar, 09/16/02.*///#include <ip.h>#include <aodv/aodv.h>#include <aodv/aodv_packet.h>#include <random.h>#include <cmu-trace.h>//#include <energy-model.h>#define max(a,b)        ( (a) > (b) ? (a) : (b) )#define CURRENT_TIME    Scheduler::instance().clock()//#define DEBUG//#define ERROR#ifdef DEBUGstatic int extra_route_reply = 0;static int limit_route_request = 0;static int route_request = 0;#endif/*  TCL Hooks*/int hdr_aodv::offset_;static class AODVHeaderClass : public PacketHeaderClass {public:        AODVHeaderClass() : PacketHeaderClass("PacketHeader/AODV",                                              sizeof(hdr_all_aodv)) {	  bind_offset(&hdr_aodv::offset_);	} } class_rtProtoAODV_hdr;static class AODVclass : public TclClass {public:        AODVclass() : TclClass("Agent/AODV") {}        TclObject* create(int argc, const char*const* argv) {          assert(argc == 5);          //return (new AODV((nsaddr_t) atoi(argv[4])));	  return (new AODV((nsaddr_t) Address::instance().str2addr(argv[4])));        }} class_rtProtoAODV;intAODV::command(int argc, const char*const* argv) {  if(argc == 2) {  Tcl& tcl = Tcl::instance();        if(strncasecmp(argv[1], "id", 2) == 0) {      tcl.resultf("%d", index);      return TCL_OK;    }        if(strncasecmp(argv[1], "start", 2) == 0) {      btimer.handle((Event*) 0);#ifndef AODV_LINK_LAYER_DETECTION      htimer.handle((Event*) 0);      ntimer.handle((Event*) 0);#endif // LINK LAYER DETECTION      rtimer.handle((Event*) 0);      return TCL_OK;     }                 }  else if(argc == 3) {    if(strcmp(argv[1], "index") == 0) {      index = atoi(argv[2]);      return TCL_OK;    }    else if(strcmp(argv[1], "log-target") == 0 || strcmp(argv[1], "tracetarget") == 0) {      logtarget = (Trace*) TclObject::lookup(argv[2]);      if(logtarget == 0)	return TCL_ERROR;      return TCL_OK;    }    else if(strcmp(argv[1], "drop-target") == 0) {    int stat = rqueue.command(argc,argv);      if (stat != TCL_OK) return stat;      return Agent::command(argc, argv);    }    else if(strcmp(argv[1], "if-queue") == 0) {    ifqueue = (PriQueue*) TclObject::lookup(argv[2]);            if(ifqueue == 0)	return TCL_ERROR;      return TCL_OK;    }  }  return Agent::command(argc, argv);}/*    Constructor*/AODV::AODV(nsaddr_t id) : Agent(PT_AODV),			  btimer(this), htimer(this), ntimer(this), 			  rtimer(this), lrtimer(this), rqueue() {                   index = id;  seqno = 2;  bid = 1;  LIST_INIT(&nbhead);  LIST_INIT(&bihead);  logtarget = 0;  ifqueue = 0;}/*  Timers*/voidBroadcastTimer::handle(Event*) {  agent->id_purge();  Scheduler::instance().schedule(this, &intr, BCAST_ID_SAVE);}voidHelloTimer::handle(Event*) {   agent->sendHello();   double interval = MinHelloInterval +                  ((MaxHelloInterval - MinHelloInterval) * Random::uniform());   assert(interval >= 0);   Scheduler::instance().schedule(this, &intr, interval);}voidNeighborTimer::handle(Event*) {  agent->nb_purge();  Scheduler::instance().schedule(this, &intr, HELLO_INTERVAL);}voidRouteCacheTimer::handle(Event*) {  agent->rt_purge();#define FREQUENCY 0.5 // sec  Scheduler::instance().schedule(this, &intr, FREQUENCY);}voidLocalRepairTimer::handle(Event* p)  {  // SRD: 5/4/99aodv_rt_entry *rt;struct hdr_ip *ih = HDR_IP( (Packet *)p);   /* you get here after the timeout in a local repair attempt */   /*	fprintf(stderr, "%s\n", __FUNCTION__); */    rt = agent->rtable.rt_lookup(ih->daddr());	    if (rt && rt->rt_flags != RTF_UP) {    // route is yet to be repaired    // I will be conservative and bring down the route    // and send route errors upstream.    /* The following assert fails, not sure why */    /* assert (rt->rt_flags == RTF_IN_REPAIR); */		      //rt->rt_seqno++;      agent->rt_down(rt);      // send RERR#ifdef DEBUG      fprintf(stderr,"Node %d: Dst - %d, failed local repair\n",index, rt->rt_dst);#endif          }    Packet::free((Packet *)p);}/*   Broadcast ID Management  Functions*/voidAODV::id_insert(nsaddr_t id, u_int32_t bid) {BroadcastID *b = new BroadcastID(id, bid); assert(b); b->expire = CURRENT_TIME + BCAST_ID_SAVE; LIST_INSERT_HEAD(&bihead, b, link);}/* SRD */boolAODV::id_lookup(nsaddr_t id, u_int32_t bid) {BroadcastID *b = bihead.lh_first;  // Search the list for a match of source and bid for( ; b; b = b->link.le_next) {   if ((b->src == id) && (b->id == bid))     return true;      } return false;}voidAODV::id_purge() {BroadcastID *b = bihead.lh_first;BroadcastID *bn;double now = CURRENT_TIME; for(; b; b = bn) {   bn = b->link.le_next;   if(b->expire <= now) {     LIST_REMOVE(b,link);     delete b;   } }}/*  Helper Functions*/doubleAODV::PerHopTime(aodv_rt_entry *rt) {int num_non_zero = 0, i;double total_latency = 0.0; if (!rt)   return ((double) NODE_TRAVERSAL_TIME );	 for (i=0; i < MAX_HISTORY; i++) {   if (rt->rt_disc_latency[i] > 0.0) {      num_non_zero++;      total_latency += rt->rt_disc_latency[i];   } } if (num_non_zero > 0)   return(total_latency / (double) num_non_zero); else   return((double) NODE_TRAVERSAL_TIME);}/*  Link Failure Management Functions*/static voidaodv_rt_failed_callback(Packet *p, void *arg) {  ((AODV*) arg)->rt_ll_failed(p);}/* * This routine is invoked when the link-layer reports a route failed. */voidAODV::rt_ll_failed(Packet *p) {struct hdr_cmn *ch = HDR_CMN(p);struct hdr_ip *ih = HDR_IP(p);aodv_rt_entry *rt;nsaddr_t broken_nbr = ch->next_hop_;#ifndef AODV_LINK_LAYER_DETECTION drop(p, DROP_RTR_MAC_CALLBACK);#else  /*  * Non-data packets and Broadcast Packets can be dropped.  */  if(! DATA_PACKET(ch->ptype()) ||     (u_int32_t) ih->daddr() == IP_BROADCAST) {    drop(p, DROP_RTR_MAC_CALLBACK);    return;  }  log_link_broke(p);	if((rt = rtable.rt_lookup(ih->daddr())) == 0) {    drop(p, DROP_RTR_MAC_CALLBACK);    return;  }  log_link_del(ch->next_hop_);#ifdef AODV_LOCAL_REPAIR  /* if the broken link is closer to the dest than source,      attempt a local repair. Otherwise, bring down the route. */  if (ch->num_forwards() > rt->rt_hops) {    local_rt_repair(rt, p); // local repair    // retrieve all the packets in the ifq using this link,    // queue the packets for which local repair is done,     return;  }  else	#endif // LOCAL REPAIR	  {    drop(p, DROP_RTR_MAC_CALLBACK);    // Do the same thing for other packets in the interface queue using the    // broken link -Maheshwhile((p = ifqueue->filter(broken_nbr))) {     drop(p, DROP_RTR_MAC_CALLBACK);    }	    nb_delete(broken_nbr);  }#endif // LINK LAYER DETECTION}voidAODV::handle_link_failure(nsaddr_t id) {aodv_rt_entry *rt, *rtn;Packet *rerr = Packet::alloc();struct hdr_aodv_error *re = HDR_AODV_ERROR(rerr); re->DestCount = 0; for(rt = rtable.head(); rt; rt = rtn) {  // for each rt entry   rtn = rt->rt_link.le_next;    if ((rt->rt_hops != INFINITY2) && (rt->rt_nexthop == id) ) {     assert (rt->rt_flags == RTF_UP);     assert((rt->rt_seqno%2) == 0);     rt->rt_seqno++;     re->unreachable_dst[re->DestCount] = rt->rt_dst;     re->unreachable_dst_seqno[re->DestCount] = rt->rt_seqno;#ifdef DEBUG     fprintf(stderr, "%s(%f): %d\t(%d\t%u\t%d)\n", __FUNCTION__, CURRENT_TIME,		     index, re->unreachable_dst[re->DestCount],		     re->unreachable_dst_seqno[re->DestCount], rt->rt_nexthop);#endif // DEBUG     re->DestCount += 1;     rt_down(rt);   }   // remove the lost neighbor from all the precursor lists   rt->pc_delete(id); }    if (re->DestCount > 0) {#ifdef DEBUG   fprintf(stderr, "%s(%f): %d\tsending RERR...\n", __FUNCTION__, CURRENT_TIME, index);#endif // DEBUG   sendError(rerr, false); } else {   Packet::free(rerr); }}voidAODV::local_rt_repair(aodv_rt_entry *rt, Packet *p) {#ifdef DEBUG  fprintf(stderr,"%s: Dst - %d\n", __FUNCTION__, rt->rt_dst); #endif    // Buffer the packet   rqueue.enque(p);  // mark the route as under repair   rt->rt_flags = RTF_IN_REPAIR;  sendRequest(rt->rt_dst);  // set up a timer interrupt  Scheduler::instance().schedule(&lrtimer, p->copy(), rt->rt_req_timeout);}voidAODV::rt_update(aodv_rt_entry *rt, u_int32_t seqnum, u_int16_t metric,	       	nsaddr_t nexthop, double expire_time) {     rt->rt_seqno = seqnum;     rt->rt_hops = metric;     rt->rt_flags = RTF_UP;     rt->rt_nexthop = nexthop;     rt->rt_expire = expire_time;}voidAODV::rt_down(aodv_rt_entry *rt) {  /*   *  Make sure that you don't "down" a route more than once.   */  if(rt->rt_flags == RTF_DOWN) {    return;  }  // assert (rt->rt_seqno%2); // is the seqno odd?  rt->rt_last_hop_count = rt->rt_hops;  rt->rt_hops = INFINITY2;  rt->rt_flags = RTF_DOWN;  rt->rt_nexthop = 0;  rt->rt_expire = 0;} /* rt_down function *//*  Route Handling Functions*/voidAODV::rt_resolve(Packet *p) {struct hdr_cmn *ch = HDR_CMN(p);struct hdr_ip *ih = HDR_IP(p);aodv_rt_entry *rt; /*  *  Set the transmit failure callback.  That  *  won't change.  */ ch->xmit_failure_ = aodv_rt_failed_callback; ch->xmit_failure_data_ = (void*) this;	rt = rtable.rt_lookup(ih->daddr()); if(rt == 0) {	  rt = rtable.rt_add(ih->daddr()); } /*  * If the route is up, forward the packet   */	 if(rt->rt_flags == RTF_UP) {   assert(rt->rt_hops != INFINITY2);   forward(rt, p, NO_DELAY); } /*  *  if I am the source of the packet, then do a Route Request.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区大片| 成人免费三级在线| 一本到三区不卡视频| 国产精品高清亚洲| 91女人视频在线观看| 午夜av一区二区| 精品乱人伦小说| 高清在线不卡av| 亚洲aⅴ怡春院| 久久久久久免费网| 91免费视频网| 日本道精品一区二区三区| 久久se精品一区二区| 国产精品久久久久9999吃药| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 一区二区三区**美女毛片| 欧美久久久久久蜜桃| 国产精品18久久久久久久久久久久| 亚洲欧美日韩国产成人精品影院 | 久久午夜免费电影| 91福利精品视频| 欧美日韩卡一卡二| 99精品久久只有精品| 九一九一国产精品| 亚洲成人激情综合网| 蜜桃一区二区三区在线| 一区二区三区久久| 日本va欧美va精品| 亚洲国产精品一区二区www| 国产精品女主播av| 亚洲精品久久嫩草网站秘色| 国产日韩视频一区二区三区| 欧美一卡2卡3卡4卡| 国产午夜亚洲精品羞羞网站| 精品久久久久久久久久久久久久久| 国产亚洲视频系列| 亚洲大片在线观看| 国产高清不卡一区| 国产91丝袜在线18| 欧美日韩一区三区四区| 在线观看视频91| 在线观看日韩毛片| 久久免费看少妇高潮| 亚洲女同ⅹxx女同tv| 久久精品国产一区二区三区免费看| 成人网页在线观看| 欧美一区二区三区公司| 亚洲日本欧美天堂| 亚洲欧美日韩成人高清在线一区| 免费高清在线视频一区·| 99精品国产视频| 欧美精品一区二区三区蜜桃| 久久久久久亚洲综合| 无吗不卡中文字幕| 91国偷自产一区二区开放时间 | 欧美日韩视频第一区| 久久久久久久久久久久久久久99 | 另类小说综合欧美亚洲| 91天堂素人约啪| 国产日韩在线不卡| 美国欧美日韩国产在线播放| 欧美视频一区二区三区| 欧美精品色一区二区三区| 日韩一区在线看| 亚洲午夜久久久久久久久久久| 风间由美性色一区二区三区| 欧美成人aa大片| 奇米一区二区三区| 91麻豆精品久久久久蜜臀| 精品国产乱码久久久久久1区2区| 首页亚洲欧美制服丝腿| 国产一区福利在线| 色综合天天性综合| 精品国精品国产| 奇米精品一区二区三区在线观看| 欧美视频在线一区| 亚洲第一综合色| 欧美日韩一区 二区 三区 久久精品 | 91国产免费看| 夜夜爽夜夜爽精品视频| 欧美色倩网站大全免费| 亚洲综合一区二区| 国产精品自在欧美一区| 久久久不卡影院| 国产99久久久久久免费看农村| 国产亚洲综合色| 99国产麻豆精品| 亚洲一区在线看| 欧美日韩国产首页在线观看| 日本成人超碰在线观看| 99视频一区二区| 精品久久人人做人人爽| 国产乱码精品1区2区3区| 欧美精彩视频一区二区三区| 国产亲近乱来精品视频| 99视频有精品| 亚洲成人一区在线| 日韩免费看网站| 亚洲成av人影院在线观看网| 欧美精品久久99久久在免费线| 麻豆国产一区二区| 国产精品青草久久| 欧美日韩免费不卡视频一区二区三区| 日韩电影一区二区三区四区| 久久久美女艺术照精彩视频福利播放| 波多野洁衣一区| 五月天中文字幕一区二区| 日韩欧美第一区| 99久久精品免费观看| 日韩中文字幕区一区有砖一区| 久久日韩精品一区二区五区| 成人动漫一区二区三区| 久久久久久电影| 在线观看视频91| 韩国精品久久久| 欧美mv日韩mv国产网站| 91污片在线观看| 老司机精品视频在线| 国产精品福利影院| 日韩一级黄色大片| 蜜乳av一区二区| 亚洲乱码一区二区三区在线观看| 欧美一区二区福利在线| 色综合久久久久网| 国产一区二区三区蝌蚪| 亚洲成人av一区| 欧美国产一区二区| 欧美电影免费观看高清完整版在线观看| 成人午夜电影网站| fc2成人免费人成在线观看播放| 亚洲成人av一区二区三区| 国产精品人妖ts系列视频| 日韩欧美在线不卡| 欧美日韩午夜精品| 99re这里只有精品视频首页| 国产在线不卡一卡二卡三卡四卡| 图片区小说区国产精品视频| 亚洲人123区| 欧美国产禁国产网站cc| 精品视频在线免费看| 成人在线视频一区二区| 国产做a爰片久久毛片| 奇米在线7777在线精品| 亚洲黄色片在线观看| 亚洲欧洲精品一区二区三区| 国产亚洲一区二区三区四区| 久久久不卡网国产精品二区| 精品国产sm最大网站| 91精品国产综合久久久蜜臀粉嫩| 91电影在线观看| 欧洲在线/亚洲| 欧美私人免费视频| 欧美午夜精品一区| 欧美日韩在线不卡| 欧美日韩不卡一区二区| 欧美日韩国产高清一区二区 | 欧美一级片在线看| 精品视频在线免费观看| 欧美日韩午夜影院| 7777精品伊人久久久大香线蕉完整版 | 奇米四色…亚洲| 理论电影国产精品| 久久99精品久久久久久国产越南| 久久精品国产免费| 国产在线视频不卡二| 国产精品99久| 99久久精品国产一区二区三区| 国产sm精品调教视频网站| 国产91精品入口| 91伊人久久大香线蕉| 91蜜桃网址入口| 欧美日韩亚洲另类| 日韩欧美在线影院| 中文一区二区完整视频在线观看| 国产精品黄色在线观看| 一区二区国产视频| 日韩av在线播放中文字幕| 久久91精品国产91久久小草| 国产福利视频一区二区三区| 91在线播放网址| 91麻豆精品国产91久久久更新时间| 精品少妇一区二区三区在线播放| 久久综合中文字幕| 亚洲男女毛片无遮挡| 青青青伊人色综合久久| 国产91在线看| 欧美精品色一区二区三区| 国产亚洲欧美日韩在线一区| 一区二区三区91| 国内外成人在线| 色天使色偷偷av一区二区| 欧美一区二区三级| 成人欧美一区二区三区小说| 日韩国产高清影视| 成人精品视频网站| 91精品国产福利| 亚洲视频一区二区免费在线观看| 青青草97国产精品免费观看 | 亚洲人成在线观看一区二区| 日韩综合一区二区|