A global global router. More...
#include "global-route-manager.h"
Public Member Functions | |
| GlobalRouteManager (const GlobalRouteManager< T > &)=delete | |
| GlobalRouteManager & | operator= (const GlobalRouteManager< T > &)=delete |
Static Public Member Functions | |
| static uint32_t | AllocateRouterId () |
| Allocate a 32-bit router ID from monotonically increasing counter. | |
| static void | BuildGlobalRoutingDatabase () |
| Build the routing database by gathering Link State Advertisements from each node exporting a GlobalRouter interface. | |
| static void | DeleteGlobalRoutes () |
| Delete all static routes on all nodes that have a GlobalRouterInterface. | |
| static void | InitializeRouters () |
| initialize all nodes as routers. | |
| static void | InitializeRoutes () |
| Compute routes using a Dijkstra SPF computation and populate per-node forwarding tables. | |
| static void | PrintRoute (Ptr< Node > sourceNode, IpAddress dest, bool nodeIdLookup=true, Time::Unit unit=Time::S) |
| prints the path from this node to the destination node at a particular time. | |
| static void | PrintRoute (Ptr< Node > sourceNode, IpAddress dest, Ptr< OutputStreamWrapper > stream, bool nodeIdLookup=true, Time::Unit unit=Time::S) |
| prints the path from this node to the destination node at a particular time. | |
| static void | PrintRoute (Ptr< Node > sourceNode, Ptr< Node > dest, bool nodeIdLookup=true, Time::Unit unit=Time::S) |
| prints the path from this node to the destination node at a particular time. | |
| static void | PrintRoute (Ptr< Node > sourceNode, Ptr< Node > dest, Ptr< OutputStreamWrapper > stream, bool nodeIdLookup=true, Time::Unit unit=Time::S) |
| prints the path from this node to the destination node at a particular time. | |
| static void | ResetRouterId () |
| Reset the router ID counter to zero. | |
Private Types | |
| using | Ip = typename std::conditional_t<IsIpv4, Ipv4, Ipv6> |
| Alias for Ipv4 and Ipv6 classes. | |
| using | IpAddress = typename std::conditional_t<IsIpv4, Ipv4Address, Ipv6Address> |
| Alias for Ipv4Address and Ipv6Address classes. | |
| using | IpManager = typename std::conditional_t<IsIpv4, Ipv4Manager, Ipv6Manager> |
| Alias for Ipv4Manager and Ipv6Manager classes. | |
Static Private Attributes | |
| static constexpr bool | IsIpv4 = std::is_same_v<Ipv4Manager, T> |
| Alias for determining whether the parent is Ipv4RoutingProtocol or Ipv6RoutingProtocol. | |
| static uint32_t | routerId |
| Router ID counter. | |
A global global router.
This singleton object can query interface each node in the system for a GlobalRouter interface. For those nodes, it fetches one or more Link State Advertisements and stores them in a local database. Then, it can compute shortest paths on a per-node basis to all routers, and finally configure each of the node's forwarding tables.
The design is guided by OSPFv2 RFC 2328 section 16.1.1 and quagga ospfd.
Definition at line 52 of file global-route-manager.h.
|
private |
Alias for Ipv4 and Ipv6 classes.
Definition at line 60 of file global-route-manager.h.
|
private |
Alias for Ipv4Address and Ipv6Address classes.
Definition at line 63 of file global-route-manager.h.
|
private |
Alias for Ipv4Manager and Ipv6Manager classes.
Definition at line 66 of file global-route-manager.h.
|
delete |
|
static |
Allocate a 32-bit router ID from monotonically increasing counter.
Definition at line 62 of file global-route-manager.cc.
References NS_LOG_FUNCTION_NOARGS, and routerId.
Referenced by ns3::GlobalRoutingLSA< ns3::Ipv4Manager >::GetStatus().
|
static |
Build the routing database by gathering Link State Advertisements from each node exporting a GlobalRouter interface.
Definition at line 44 of file global-route-manager.cc.
References NS_LOG_FUNCTION_NOARGS.
Referenced by ns3::GlobalRouting< T >::NotifyAddAddress(), ns3::GlobalRouting< T >::NotifyInterfaceDown(), ns3::GlobalRouting< T >::NotifyInterfaceUp(), ns3::GlobalRouting< T >::NotifyRemoveAddress(), ns3::Ipv6GlobalRoutingHelper::PopulateRoutingTables(), and ns3::Ipv6GlobalRoutingHelper::RecomputeRoutingTables().
|
static |
Delete all static routes on all nodes that have a GlobalRouterInterface.
Definition at line 35 of file global-route-manager.cc.
References NS_LOG_FUNCTION_NOARGS.
Referenced by ns3::GlobalRouting< T >::NotifyAddAddress(), ns3::GlobalRouting< T >::NotifyInterfaceDown(), ns3::GlobalRouting< T >::NotifyInterfaceUp(), ns3::GlobalRouting< T >::NotifyRemoveAddress(), and ns3::Ipv6GlobalRoutingHelper::RecomputeRoutingTables().
|
static |
initialize all nodes as routers.
this method queries all the nodes in the simulation and enables ipv6 forwarding on all of them.
Definition at line 147 of file global-route-manager.cc.
Referenced by ns3::Ipv6GlobalRoutingHelper::PopulateRoutingTables().
|
static |
Compute routes using a Dijkstra SPF computation and populate per-node forwarding tables.
Definition at line 53 of file global-route-manager.cc.
References NS_LOG_FUNCTION_NOARGS.
Referenced by ns3::GlobalRouting< T >::NotifyAddAddress(), ns3::GlobalRouting< T >::NotifyInterfaceDown(), ns3::GlobalRouting< T >::NotifyInterfaceUp(), ns3::GlobalRouting< T >::NotifyRemoveAddress(), ns3::Ipv6GlobalRoutingHelper::PopulateRoutingTables(), and ns3::Ipv6GlobalRoutingHelper::RecomputeRoutingTables().
|
delete |
|
static |
prints the path from this node to the destination node at a particular time.
| sourceNode | The source node. |
| dest | The IP address of the destination node. |
| nodeIdLookup | Print the Node Id |
| unit | The time unit for timestamps in the printed output. |
Definition at line 101 of file global-route-manager.cc.
References ns3::Create(), and PrintRoute().
|
static |
prints the path from this node to the destination node at a particular time.
| sourceNode | The source node. |
| dest | The IPv4 address of the destination node. |
| stream | The output stream to which the routing path will be written. |
| nodeIdLookup | Print the Node Id |
| unit | The time unit for timestamps in the printed output. |
Definition at line 77 of file global-route-manager.cc.
References ns3::Time::As(), and ns3::Now().
Referenced by PrintRoute(), PrintRoute(), ns3::Ipv4GlobalRoutingHelper::PrintRoute(), ns3::Ipv4GlobalRoutingHelper::PrintRoute(), ns3::Ipv4GlobalRoutingHelper::PrintRoute(), and ns3::Ipv4GlobalRoutingHelper::PrintRoute().
|
static |
prints the path from this node to the destination node at a particular time.
| sourceNode | The source node. |
| dest | The destination node. |
| nodeIdLookup | Print the Node Id |
| unit | The time unit for timestamps in the printed output. |
Definition at line 136 of file global-route-manager.cc.
References ns3::Create(), and PrintRoute().
|
static |
prints the path from this node to the destination node at a particular time.
| sourceNode | The source node. |
| dest | The destination node. |
| stream | The output stream to which the routing path will be written. |
| nodeIdLookup | Print the Node Id |
| unit | The time unit for timestamps in the printed output. |
Definition at line 112 of file global-route-manager.cc.
References ns3::Time::As(), and ns3::Now().
|
static |
Reset the router ID counter to zero.
This should only be called by tests to reset the router ID counter between simulations within the same program. This function should not be called In typical simulations or when using the GlobalRouting helper.
Definition at line 70 of file global-route-manager.cc.
References routerId.
Referenced by GlobalRoutingv4ProtocolTestCase::DoRun(), GlobalRoutingv6ProtocolTestCase::DoRun(), LanRoutesTestCase::DoRun(), and LinkRoutesTestCase::DoRun().
|
staticconstexprprivate |
Alias for determining whether the parent is Ipv4RoutingProtocol or Ipv6RoutingProtocol.
Definition at line 57 of file global-route-manager.h.
|
staticprivate |
Router ID counter.
Definition at line 168 of file global-route-manager.h.
Referenced by AllocateRouterId(), and ResetRouterId().