A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
ns3::GlobalRouteManager Class Reference

A global global router. More...

#include "global-route-manager.h"

Collaboration diagram for ns3::GlobalRouteManager:

Public Member Functions

 GlobalRouteManager (const GlobalRouteManager &)=delete
GlobalRouteManageroperator= (const GlobalRouteManager &)=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 InitializeRoutes ()
 Compute routes using a Dijkstra SPF computation and populate per-node forwarding tables.
static void PrintRoute (Ptr< Node > sourceNode, Ipv4Address 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, Ipv4Address 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.

Static Private Attributes

static uint32_t routerId = 0
 Router ID counter.

Detailed Description

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 33 of file global-route-manager.h.

Constructor & Destructor Documentation

◆ GlobalRouteManager()

ns3::GlobalRouteManager::GlobalRouteManager ( const GlobalRouteManager & )
delete

References GlobalRouteManager().

Referenced by GlobalRouteManager(), and operator=().

Here is the call graph for this function:
Here is the caller graph for this function:

Member Function Documentation

◆ AllocateRouterId()

uint32_t ns3::GlobalRouteManager::AllocateRouterId ( )
static

Allocate a 32-bit router ID from monotonically increasing counter.

Returns
A new new RouterId.

Definition at line 54 of file global-route-manager.cc.

References NS_LOG_FUNCTION_NOARGS, and routerId.

Referenced by ns3::GlobalRouter::GlobalRouter().

Here is the caller graph for this function:

◆ BuildGlobalRoutingDatabase()

void ns3::GlobalRouteManager::BuildGlobalRoutingDatabase ( )
static

Build the routing database by gathering Link State Advertisements from each node exporting a GlobalRouter interface.

Definition at line 40 of file global-route-manager.cc.

References ns3::SimulationSingleton< T >::Get(), and NS_LOG_FUNCTION_NOARGS.

Referenced by ns3::Ipv4GlobalRouting::NotifyAddAddress(), ns3::Ipv4GlobalRouting::NotifyInterfaceDown(), ns3::Ipv4GlobalRouting::NotifyInterfaceUp(), ns3::Ipv4GlobalRouting::NotifyRemoveAddress(), ns3::Ipv4GlobalRoutingHelper::PopulateRoutingTables(), and ns3::Ipv4GlobalRoutingHelper::RecomputeRoutingTables().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ DeleteGlobalRoutes()

void ns3::GlobalRouteManager::DeleteGlobalRoutes ( )
static

Delete all static routes on all nodes that have a GlobalRouterInterface.

Definition at line 33 of file global-route-manager.cc.

References ns3::SimulationSingleton< T >::Get(), and NS_LOG_FUNCTION_NOARGS.

Referenced by ns3::Ipv4GlobalRouting::NotifyAddAddress(), ns3::Ipv4GlobalRouting::NotifyInterfaceDown(), ns3::Ipv4GlobalRouting::NotifyInterfaceUp(), ns3::Ipv4GlobalRouting::NotifyRemoveAddress(), and ns3::Ipv4GlobalRoutingHelper::RecomputeRoutingTables().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ InitializeRoutes()

void ns3::GlobalRouteManager::InitializeRoutes ( )
static

Compute routes using a Dijkstra SPF computation and populate per-node forwarding tables.

Definition at line 47 of file global-route-manager.cc.

References ns3::SimulationSingleton< T >::Get(), and NS_LOG_FUNCTION_NOARGS.

Referenced by ns3::Ipv4GlobalRouting::NotifyAddAddress(), ns3::Ipv4GlobalRouting::NotifyInterfaceDown(), ns3::Ipv4GlobalRouting::NotifyInterfaceUp(), ns3::Ipv4GlobalRouting::NotifyRemoveAddress(), ns3::Ipv4GlobalRoutingHelper::PopulateRoutingTables(), and ns3::Ipv4GlobalRoutingHelper::RecomputeRoutingTables().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ operator=()

GlobalRouteManager & ns3::GlobalRouteManager::operator= ( const GlobalRouteManager & )
delete

References GlobalRouteManager(), and ns3::Time::S.

Here is the call graph for this function:

◆ PrintRoute() [1/4]

void ns3::GlobalRouteManager::PrintRoute ( Ptr< Node > sourceNode,
Ipv4Address dest,
bool nodeIdLookup = true,
Time::Unit unit = Time::S )
static

prints the path from this node to the destination node at a particular time.

Parameters
sourceNodeThe source node.
destThe IPv4 address of the destination node.
nodeIdLookupPrint the Node Id
unitThe time unit for timestamps in the printed output.
See also
Ipv4GlobalRoutingHelper::PrintRoute

Definition at line 90 of file global-route-manager.cc.

References ns3::Create(), and PrintRoute().

Here is the call graph for this function:

◆ PrintRoute() [2/4]

void ns3::GlobalRouteManager::PrintRoute ( Ptr< Node > sourceNode,
Ipv4Address dest,
Ptr< OutputStreamWrapper > stream,
bool nodeIdLookup = true,
Time::Unit unit = Time::S )
static

prints the path from this node to the destination node at a particular time.

Parameters
sourceNodeThe source node.
destThe IPv4 address of the destination node.
streamThe output stream to which the routing path will be written.
nodeIdLookupPrint the Node Id
unitThe time unit for timestamps in the printed output.
See also
Ipv4GlobalRoutingHelper::PrintRoute

Definition at line 67 of file global-route-manager.cc.

References ns3::Time::As(), ns3::SimulationSingleton< T >::Get(), and ns3::Now().

Referenced by PrintRoute(), PrintRoute(), ns3::Ipv4GlobalRoutingHelper::PrintRoute(), ns3::Ipv4GlobalRoutingHelper::PrintRoute(), ns3::Ipv4GlobalRoutingHelper::PrintRoute(), and ns3::Ipv4GlobalRoutingHelper::PrintRoute().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ PrintRoute() [3/4]

void ns3::GlobalRouteManager::PrintRoute ( Ptr< Node > sourceNode,
Ptr< Node > dest,
bool nodeIdLookup = true,
Time::Unit unit = Time::S )
static

prints the path from this node to the destination node at a particular time.

Parameters
sourceNodeThe source node.
destThe destination node.
nodeIdLookupPrint the Node Id
unitThe time unit for timestamps in the printed output.
See also
Ipv4GlobalRoutingHelper::PrintRoute

Definition at line 123 of file global-route-manager.cc.

References ns3::Create(), and PrintRoute().

Here is the call graph for this function:

◆ PrintRoute() [4/4]

void ns3::GlobalRouteManager::PrintRoute ( Ptr< Node > sourceNode,
Ptr< Node > dest,
Ptr< OutputStreamWrapper > stream,
bool nodeIdLookup = true,
Time::Unit unit = Time::S )
static

prints the path from this node to the destination node at a particular time.

Parameters
sourceNodeThe source node.
destThe destination node.
streamThe output stream to which the routing path will be written.
nodeIdLookupPrint the Node Id
unitThe time unit for timestamps in the printed output.
See also
Ipv4GlobalRoutingHelper::PrintRoute

Definition at line 100 of file global-route-manager.cc.

References ns3::Time::As(), ns3::SimulationSingleton< T >::Get(), and ns3::Now().

Here is the call graph for this function:

◆ ResetRouterId()

void ns3::GlobalRouteManager::ResetRouterId ( )
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 61 of file global-route-manager.cc.

References routerId.

Referenced by GlobalRoutingProtocolTestCase::DoRun(), LanRoutesTestCase::DoRun(), and LinkRoutesTestCase::DoRun().

Here is the caller graph for this function:

Member Data Documentation

◆ routerId

uint32_t ns3::GlobalRouteManager::routerId = 0
staticprivate

Router ID counter.

Definition at line 129 of file global-route-manager.h.

Referenced by AllocateRouterId(), and ResetRouterId().


The documentation for this class was generated from the following files: