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

📄 dsragent.h

📁 动态路由协议dsr改进算法
💻 H
字号:
/* * dsragent.h * Copyright (C) 2000 by the University of Southern California * $Id: dsragent.h,v 1.10 2005/08/25 18:58:04 johnh Exp $ * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License, * version 2, as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA. * * * The copyright of this module includes the following * linking-with-specific-other-licenses addition: * * In addition, as a special exception, the copyright holders of * this module give you permission to combine (via static or * dynamic linking) this module with free software programs or * libraries that are released under the GNU LGPL and with code * included in the standard release of ns-2 under the Apache 2.0 * license or under otherwise-compatible licenses with advertising * requirements (or modified versions of such code, with unchanged * license).  You may copy and distribute such a system following the * terms of the GNU GPL for this module and the licenses of the * other code concerned, provided that you include the source code of * that other code when and as the GNU GPL requires distribution of * source code. * * Note that people who make modified versions of this module * are not obligated to grant this special exception for their * modified versions; it is their choice whether to do so.  The GNU * General Public License gives permission to release a modified * version without this exception; this exception also makes it * possible to release a modified version which carries forward this * exception. * */// Other copyrights might apply to parts of this software and are so noted when applicable.//// Ported from CMU/Monarch's code, appropriate copyright applies.  /* -*- c++ -*-   dsragent.h   */#ifndef _DSRAgent_h#define _DSRAgent_hclass DSRAgent;#include <stdarg.h>#include <object.h>#include <agent.h>#include <trace.h>#include <packet.h>#include <dsr-priqueue.h>#include <mac.h>#include <mobilenode.h>#include "path.h"#include "srpacket.h"#include "routecache.h"#include "requesttable.h"#include "flowstruct.h"#define BUFFER_CHECK 0.03	// seconds between buffer checks#define RREQ_JITTER 0.010	// seconds to jitter broadcast route requests#define SEND_TIMEOUT 30.0	// # seconds a packet can live in sendbuf#define SEND_BUF_SIZE 64#define RTREP_HOLDOFF_SIZE 10#define GRAT_ROUTE_ERROR 0	// tell_addr indicating a grat route err#define DSR_FILTER_TAP		/* process a packet only once via the tap */class ArpCallbackClass;struct RtRepHoldoff {  ID requestor;  ID requested_dest;  int best_length;  int our_length;};struct SendBufEntry {  Time t;			// insertion time  SRPacket p;};struct GratReplyHoldDown {  Time t;  Path p;};class SendBufferTimer : public TimerHandler {public:  SendBufferTimer(DSRAgent *a) : TimerHandler() { a_ = a;}  void expire(Event *e);protected:  DSRAgent *a_;};LIST_HEAD(DSRAgent_List, DSRAgent);class DSRAgent : public Tap, public Agent {public:  virtual int command(int argc, const char*const* argv);  virtual void recv(Packet*, Handler* callback = 0);  void tap(const Packet *p);  // tap out all data packets received at this host and promiscously snoop  // them for interesting tidbits  void Terminate(void);	// called at the end of the simulation to purge all packets  void sendOutBCastPkt(Packet *p);    DSRAgent();  ~DSRAgent();private:  Trace *logtarget;  int off_mac_;  int off_ll_;  int off_ip_;  int off_sr_;  // will eventually need to handle multiple infs, but this is okay for  // now 1/28/98 -dam  ID net_id, MAC_id;		// our IP addr and MAC addr  NsObject *ll;		        // our link layer output   CMUPriQueue *ifq;		// output interface queue  Mac *mac_;  // extensions for wired cum wireless sim mode  MobileNode *node_;  int diff_subnet(ID dest, ID myid);    // extensions for mobileIP  NsObject *port_dmux_;    // my port dmux  #ifdef DSR_FILTER_TAP#define TAP_CACHE_SIZE	1024#define TAP_BITMASK	(TAP_CACHE_SIZE - 1)  /*   *  A cache of recently seen packets on the TAP so that I   *  don't process them over and over again.   */  int tap_uid_cache[TAP_CACHE_SIZE];#endif  /******** internal state ********/  RequestTable request_table;  RouteCache *route_cache;  SendBufEntry send_buf[SEND_BUF_SIZE];  SendBufferTimer send_buf_timer;  int route_request_num;	// number for our next route_request  int num_heldoff_rt_replies;  RtRepHoldoff rtrep_holdoff[RTREP_HOLDOFF_SIZE]; // not used 1/27/98  GratReplyHoldDown grat_hold[RTREP_HOLDOFF_SIZE];  int grat_hold_victim;  /* for flow state ych 5/2/01 */  FlowTable flow_table;  ARSTable  ars_table;  bool route_error_held; // are we holding a rt err to propagate?  ID err_from, err_to;	 // data from the last route err sent to us   Time route_error_data_time; // time err data was filled in  /****** internal helper functions ******/  /* all handle<blah> functions either free or hand off the      p.pkt handed to them */  void handlePktWithoutSR(SRPacket& p, bool retry);  /* obtain a source route to p's destination and send it off */  void handlePacketReceipt(SRPacket& p);  void handleForwarding(SRPacket& p);  void handleRouteRequest(SRPacket &p);  /* process a route request that isn't targeted at us */  /* flow state handle functions ych */  void handleFlowForwarding(SRPacket &p);  void handleFlowForwarding(SRPacket &p, int flowidx);  void handleDefaultForwarding(SRPacket &p);  bool ignoreRouteRequestp(SRPacket& p);  // assumes p is a route_request: answers true if it should be ignored.  // does not update the request table (you have to do that yourself if  // you want this packet ignored in the future)  void sendOutPacketWithRoute(SRPacket& p, bool fresh, Time delay = 0.0);  // take packet and send it out packet must a have a route in it  // fresh determines whether route is reset first  // time at which packet is sent is scheduled delay secs in the future  // pkt.p is freed or handed off  void sendOutRtReq(SRPacket &p, int max_prop = MAX_SR_LEN);  // turn p into a route request and launch it, max_prop of request is  // set as specified  // p.pkt is freed or handed off  void getRouteForPacket(SRPacket &p, bool retry);  /* try to obtain a route for packet     pkt is freed or handed off as needed, unless in_buffer == true     in which case they are not touched */  void acceptRouteReply(SRPacket &p);  /* - enter the packet's source route into our cache     - see if any packets are waiting to be sent out with this source route     - doesn't free the p.pkt */  void returnSrcRouteToRequestor(SRPacket &p);  // take the route in p, add us to the end of it and return the  // route to the sender of p  // doesn't free p.pkt  bool replyFromRouteCache(SRPacket &p);   /* - see if can reply to this route request from our cache     if so, do it and return true, otherwise, return false      - frees or hands off p.pkt i ff returns true */  void processUnknownFlowError(SRPacket &p, bool asDefault);  void processFlowARS(const Packet *packet);  // same idea as below, but for unknown flow error  void processBrokenRouteError(SRPacket& p);  // take the error packet and proccess our part of it.  // if needed, send the remainder of the errors to the next person  // doesn't free p.pkt  void sendUnknownFlow(SRPacket &p, bool asDefault, u_int16_t flowid = 0);  void xmitFailed(Packet *pkt, const char* reason = "DROP_RTR_MAC_CALLBACK");  void xmitFlowFailed(Packet *pkt, const char* reason = "DROP_RTR_MAC_CALLBACK");  /* mark our route cache reflect the failure of the link between     srh[cur_addr] and srh[next_addr], and then create a route err     message to send to the orginator of the pkt (srh[0])      p.pkt freed or handed off */    void undeliverablePkt(Packet *p, int mine);  /* when we've got a packet we can't deliver, what to do with it?      frees or hands off p if mine = 1, doesn't hurt it otherwise */  void dropSendBuff(SRPacket &p);  // log p as being dropped by the sendbuffer in DSR agent    void stickPacketInSendBuffer(SRPacket& p);    void sendBufferCheck();  // see if any packets in send buffer need route requests sent out  // for them, or need to be expired  void sendRouteShortening(SRPacket &p, int heard_at, int xmit_at);  // p was overheard at heard_at in it's SR, but we aren't supposed to  // get it till xmit_at, so all the nodes between heard_at and xmit_at  // can be elided.  Send originator of p a gratuitous route reply to   // tell them this.  void testinit();  void trace(char* fmt, ...);  friend void XmitFailureCallback(Packet *pkt, void *data);  friend void XmitFlowFailureCallback(Packet *pkt, void *data);  friend int FilterFailure(Packet *p, void *data);  friend class SendBufferTimer;#if 0  void scheduleRouteReply(Time t, Packet *new_p);  // schedule a time to send new_p if we haven't heard a better  // answer in the mean time.  Do not modify new_p after calling this  void snoopForRouteReplies(Time t, Packet *p);  friend void RouteReplyHoldoffCallback(Node *node, Time time, EventData *data);#endif //0  /* the following variables are used to send end-of-sim notices to all objects */public:	LIST_ENTRY(DSRAgent) link;	static DSRAgent_List agthead;};#endif // _DSRAgent_h

⌨️ 快捷键说明

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