⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 routecache.cc

📁 CBRP协议(移动adhoc中基于分簇的路由协议)ns2下的源码
💻 CC
字号:
/* routecache.cc   $Id: routecache.cc,v 1.19 1998/06/10 17:49:01 dmaltz Exp $   handles routes*/extern "C" {#include <stdio.h>#include <stdarg.h>};#undef DEBUG#include "path.h"#include "routecache.h"#include <cmu/god.h>static const int verbose_debug = 0;/*===============================================================  OTcl definition----------------------------------------------------------------*/static class RouteCacheClass : public TclClass {public:        RouteCacheClass() : TclClass("RouteCache") {}        TclObject* create(int, const char*const*) {                return makeRouteCache();        }} class_RouteCache;/*=============================================================== Constructors----------------------------------------------------------------*/RouteCache::RouteCache():#ifdef DSR_CACHE_STATS	mh(this),#endif	MAC_id(invalid_addr), net_id(invalid_addr){#ifdef DSR_CACHE_STATS	stat.reset();#endif}RouteCache::~RouteCache(){}intRouteCache::command(int argc, const char*const* argv){  if(argc == 2)    {      if(strcasecmp(argv[1], "startdsr") == 0)	{#ifdef DSR_CACHE_STATS	  mh.start();#endif	  return TCL_OK;	}    }  else if(argc == 3)     {          if (strcasecmp(argv[1], "ip-addr") == 0) {	net_id = ID(atoi(argv[2]), ::IP);	return TCL_OK;      }      else if(strcasecmp(argv[1], "mac-addr") == 0) {	MAC_id = ID(atoi(argv[2]), ::MAC);      return TCL_OK;      }            /* must be a looker up */      TclObject *obj = (TclObject*) TclObject::lookup(argv[2]);      if(obj == 0)	return TCL_ERROR;            if(strcasecmp(argv[1], "log-target") == 0) {	logtarget = (Trace*) obj;	return TCL_OK;      }      return TCL_ERROR;    }    return TclObject::command(argc, argv);}voidRouteCache::trace(char* fmt, ...){  va_list ap;    if (!logtarget) return;  va_start(ap, fmt);  vsprintf(logtarget->buffer(), fmt, ap);  logtarget->dump();  va_end(ap);}voidRouteCache::dump(FILE *out){  fprintf(out, "Route cache dump unimplemented\n");  fflush(out);}///////////////////////////////////////////////////////////////////////////extern bool cache_ignore_hints;extern bool cache_use_overheard_routes;#define STOP_PROCESSING 0#define CONT_PROCESSING 1intRouteCache::pre_addRoute(const Path& route, Path& rt,			 Time t, const ID& who_from){  assert(!(net_id == invalid_addr));    if (route.length() < 2)    return STOP_PROCESSING; // we laugh in your face  if(verbose_debug)    trace("SRC %.9f _%s_ adding rt %s from %s",	  Scheduler::instance().clock(), net_id.dump(),	  route.dump(), who_from.dump());  if (route[0] != net_id && route[0] != MAC_id)     {      fprintf(stderr,"%.9f _%s_ adding bad route to cache %s %s\n",	      t, net_id.dump(), who_from.dump(), route.dump());      return STOP_PROCESSING;    }	       rt = (Path&) route;	// cast away const Path&  rt.owner() = who_from;  Link_Type kind = LT_TESTED;  for (int c = 0; c < rt.length(); c++)    {      rt[c].log_stat = LS_UNLOGGED;      if (rt[c] == who_from) kind = LT_UNTESTED; // remaining ids came from $      rt[c].link_type = kind;      rt[c].t = t;    }  return CONT_PROCESSING;}intRouteCache::pre_noticeRouteUsed(const Path& p, Path& stub,				Time t, const ID& who_from){  int c;  bool first_tested = true;  if (p.length() < 2)	  return STOP_PROCESSING;  if (cache_ignore_hints == true)	  return STOP_PROCESSING;  for (c = 0; c < p.length() ; c++) {	  if (p[c] == net_id || p[c] == MAC_id) break;  }  if (c == p.length() - 1)	  return STOP_PROCESSING; // path contains only us  if (c == p.length()) { // we aren't in the path...	  if (cache_use_overheard_routes) {		  // assume a link from us to the person who		  // transmitted the packet		  if (p.index() == 0) {			   /* must be a route request */			  return STOP_PROCESSING;		  }		  stub.reset();		  stub.appendToPath(net_id);		  int i = p.index() - 1;		  for ( ; i < p.length() && !stub.full() ; i++) {			  stub.appendToPath(p[i]);		  }		  // link to xmiter might be unidirectional		  first_tested = false;	  }	  else {		  return STOP_PROCESSING;	  }  }  else { // we are in the path, extract the subpath	  CopyIntoPath(stub, p, c, p.length() - 1);  }  Link_Type kind = LT_TESTED;  for (c = 0; c < stub.length(); c++) {	  stub[c].log_stat = LS_UNLOGGED;	   // remaining ids came from $	  if (stub[c] == who_from)		  kind = LT_UNTESTED;	  stub[c].link_type = kind;	  stub[c].t = t;  }  if (first_tested == false)	  stub[0].link_type = LT_UNTESTED;  return CONT_PROCESSING;}#undef STOP_PROCESSING#undef CONT_PROCESSING//////////////////////////////////////////////////////////////////////#ifdef DSR_CACHE_STATSvoidMobiHandler::handle(Event *) {        cache->periodic_checkCache();        Scheduler::instance().schedule(this, &intr, interval);}intRouteCache::checkRoute_logall(Path *p, int action, int start){  int c;  int subroute_bad_count = 0;  if(p->length() == 0)    return 0;  assert(p->length() >= 2);  assert(action == ACTION_DEAD_LINK ||         action == ACTION_EVICT ||         action == ACTION_FIND_ROUTE);  for (c = start; c < p->length() - 1; c++)    {      if (God::instance()->hops((*p)[c].getNSAddr_t(), (*p)[c+1].getNSAddr_t()) != 1)	{          trace("SRC %.9f _%s_ %s [%d %d] %s->%s dead %d %.9f",                Scheduler::instance().clock(), net_id.dump(),                action_name[action], p->length(), c,                (*p)[c].dump(), (*p)[c+1].dump(),                (*p)[c].link_type, (*p)[c].t);          if(subroute_bad_count == 0)            subroute_bad_count = p->length() - c - 1;	}    }  return subroute_bad_count;}#endif /* DSR_CACHE_STAT */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -