satroute.h
上传用户:rrhhcc
上传日期:2015-12-11
资源大小:54129k
文件大小:4k
源码类别:

通讯编程

开发平台:

Visual C++

  1. /* -*-  Mode:C++; c-basic-offset:8; tab-width:8; indent-tabs-mode:t -*- */
  2. /*
  3.  * Copyright (c) 1999 Regents of the University of California.
  4.  * All rights reserved.
  5.  *
  6.  * Redistribution and use in source and binary forms, with or without
  7.  * modification, are permitted provided that the following conditions
  8.  * are met:
  9.  * 1. Redistributions of source code must retain the above copyright
  10.  *    notice, this list of conditions and the following disclaimer.
  11.  * 2. Redistributions in binary form must reproduce the above copyright
  12.  *    notice, this list of conditions and the following disclaimer in the
  13.  *    documentation and/or other materials provided with the distribution.
  14.  * 3. All advertising materials mentioning features or use of this software
  15.  *    must display the following acknowledgement:
  16.  *      This product includes software developed by the MASH Research
  17.  *      Group at the University of California Berkeley.
  18.  * 4. Neither the name of the University nor of the Research Group may be
  19.  *    used to endorse or promote products derived from this software without
  20.  *    specific prior written permission.
  21.  *
  22.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  23.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  24.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  25.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  26.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  27.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  28.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  29.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  30.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  31.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  32.  * SUCH DAMAGE.
  33.  *
  34.  * @(#) $Header: /cvsroot/nsnam/ns-2/satellite/satroute.h,v 1.4 2005/05/19 03:19:02 tomh Exp $
  35.  *
  36.  * Contributed by Tom Henderson, UCB Daedalus Research Group, June 1999
  37.  */
  38. #ifndef ns_satroute_h_
  39. #define ns_satroute_h_
  40. #include <agent.h>
  41. #include "route.h"
  42. #include "node.h"
  43. #define ROUTER_PORT      0xff
  44. #define SAT_ROUTE_INFINITY 0x3fff
  45. // Entry in the forwarding table
  46. struct slot_entry {
  47. int next_hop;
  48. NsObject* entry;
  49. };
  50. class SatNode;
  51. //
  52. //  Currently, this only implements centralized routing.  However, by 
  53. //  following the examples in the mobility code, one could build on this
  54. //  agent to make it a distributed routing agent
  55. //
  56. class SatRouteAgent : public Agent {
  57. public:
  58.   SatRouteAgent();
  59.   ~SatRouteAgent();
  60.   int command(int argc, const char * const * argv);
  61.   // centralized routing
  62.   void clear_slots();
  63.   void install(int dst, int next_hop, NsObject* p);
  64.   SatNode* node() { return node_; }
  65.   int myaddr() {return myaddr_; }
  66.   
  67. protected:
  68.   virtual void recv(Packet *, Handler *);
  69.   void forwardPacket(Packet*);
  70.   int myaddr_;           // My address-- set from OTcl
  71.   // centralized routing stuff
  72.   int maxslot_;
  73.   int nslot_;
  74.   slot_entry* slot_; // Node's forwarding table 
  75.   void alloc(int); // Helper function
  76.   SatNode* node_;
  77.   
  78. };
  79. ////////////////////////////////////////////////////////////////////////////
  80. // A global route computation object/genie  
  81. // This class performs operations very similar to what "Simulator instproc
  82. // compute-routes" does at OTcl-level, except it performs them entirely
  83. // in C++.  Single source shortest path routing is also supported.
  84. class SatRouteObject : public RouteLogic {
  85. public:
  86.   SatRouteObject(); 
  87.   static SatRouteObject& instance() {
  88. return (*instance_);            // general access to route object
  89.   }
  90.   void recompute();
  91.   void recompute_node(int node);
  92.   int command(int argc, const char * const * argv);        
  93.   int data_driven_computation() { return data_driven_computation_; } 
  94.   void insert_link(int src, int dst, double cost);
  95.   void insert_link(int src, int dst, double cost, void* entry);
  96.   int wiredRouting() { return wiredRouting_;}
  97. //void hier_insert_link(int *src, int *dst, int cost);  // support hier-rtg?
  98. protected:
  99.   void compute_topology();
  100.   void populate_routing_tables(int node = -1);
  101.   int lookup(int src, int dst);
  102.   void* lookup_entry(int src, int dst);
  103.   void node_compute_routes(int node);
  104.   void dump(); // for debugging only
  105.   static SatRouteObject*  instance_;
  106.   int metric_delay_;
  107.   int suppress_initial_computation_;
  108.   int data_driven_computation_;
  109.   int wiredRouting_;
  110. };
  111. #endif