A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
nix-vector-routing.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2009 The Georgia Institute of Technology
3 * Copyright (c) 2021 NITK Surathkal
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation;
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 *
18 * This file is adapted from the old ipv4-nix-vector-routing.h.
19 *
20 * Authors: Josh Pelkey <jpelkey@gatech.edu>
21 *
22 * Modified by: Ameya Deshpande <ameyanrd@outlook.com>
23 */
24
25#ifndef NIX_VECTOR_ROUTING_H
26#define NIX_VECTOR_ROUTING_H
27
28#include "ns3/bridge-net-device.h"
29#include "ns3/channel.h"
30#include "ns3/ipv4-interface.h"
31#include "ns3/ipv4-l3-protocol.h"
32#include "ns3/ipv4-route.h"
33#include "ns3/ipv4-routing-protocol.h"
34#include "ns3/ipv6-interface.h"
35#include "ns3/ipv6-l3-protocol.h"
36#include "ns3/ipv6-route.h"
37#include "ns3/ipv6-routing-protocol.h"
38#include "ns3/net-device-container.h"
39#include "ns3/nix-vector.h"
40#include "ns3/node-container.h"
41#include "ns3/node-list.h"
42#include "ns3/nstime.h"
43
44#include <map>
45#include <unordered_map>
46
47// NOLINTBEGIN(modernize-use-override)
48
49namespace ns3
50{
51
52/**
53 * \defgroup nix-vector-routing Nix-Vector Routing
54 *
55 * Nix-vector routing is a simulation specific routing protocol and is
56 * intended for large network topologies.
57 */
58
59/**
60 * \ingroup nix-vector-routing
61 * Nix-vector routing protocol
62 *
63 * \internal
64 * Since this class is meant to be specialized only by Ipv4RoutingProtocol or
65 * Ipv6RoutingProtocol the implementation of this class doesn't need to be
66 * exposed here; it is in nix-vector-routing.cc.
67 */
68template <typename T>
69class NixVectorRouting : public std::enable_if_t<std::is_same_v<Ipv4RoutingProtocol, T> ||
70 std::is_same_v<Ipv6RoutingProtocol, T>,
71 T>
72{
73 /// Alias for determining whether the parent is Ipv4RoutingProtocol or Ipv6RoutingProtocol
74 static constexpr bool IsIpv4 = std::is_same_v<Ipv4RoutingProtocol, T>;
75
76 /// Alias for Ipv4 and Ipv6 classes
77 using Ip = typename std::conditional_t<IsIpv4, Ipv4, Ipv6>;
78
79 /// Alias for Ipv4Address and Ipv6Address classes
80 using IpAddress = typename std::conditional_t<IsIpv4, Ipv4Address, Ipv6Address>;
81
82 /// Alias for Ipv4Route and Ipv6Route classes
83 using IpRoute = typename std::conditional_t<IsIpv4, Ipv4Route, Ipv6Route>;
84
85 /// Alias for Ipv4AddressHash and Ipv6AddressHash classes
86 using IpAddressHash = typename std::conditional_t<IsIpv4, Ipv4AddressHash, Ipv6AddressHash>;
87
88 /// Alias for Ipv4Header and Ipv6Header classes
89 using IpHeader = typename std::conditional_t<IsIpv4, Ipv4Header, Ipv6Header>;
90
91 /// Alias for Ipv4InterfaceAddress and Ipv6InterfaceAddress classes
93 typename std::conditional_t<IsIpv4, Ipv4InterfaceAddress, Ipv6InterfaceAddress>;
94
95 /// Alias for Ipv4Interface and Ipv6Interface classes
96 using IpInterface = typename std::conditional_t<IsIpv4, Ipv4Interface, Ipv6Interface>;
97
98 /// Alias for Ipv4L3Protocol and Ipv4L3Protocol classes
99 using IpL3Protocol = typename std::conditional_t<IsIpv4, Ipv4L3Protocol, Ipv6L3Protocol>;
100
101 public:
104 /**
105 * @brief The Interface ID of the Global Router interface.
106 * @return The Interface ID
107 * @see Object::GetObject ()
108 */
109 static TypeId GetTypeId();
110 /**
111 * @brief Set the Node pointer of the node for which this
112 * routing protocol is to be placed
113 *
114 * @param node Node pointer
115 */
116 void SetNode(Ptr<Node> node);
117
118 /**
119 * @brief Called when run-time link topology change occurs
120 * which iterates through the node list and flushes any
121 * nix vector caches
122 *
123 * \internal
124 * \c const is used here due to need to potentially flush the cache
125 * in const methods such as PrintRoutingTable. Caches are stored in
126 * mutable variables and flushed in const methods.
127 */
128 void FlushGlobalNixRoutingCache() const;
129
130 /**
131 * @brief Print the Routing Path according to Nix Routing
132 * \param source Source node
133 * \param dest Destination node address
134 * \param stream The ostream the Routing path is printed to
135 * \param unit the time unit to be used in the report
136 *
137 * \note IpAddress is alias for either Ipv4Address or Ipv6Address
138 * depending on on whether the network is IPv4 or IPv6 respectively.
139 */
140 void PrintRoutingPath(Ptr<Node> source,
141 IpAddress dest,
143 Time::Unit unit) const;
144
145 private:
146 /**
147 * Flushes the cache which stores nix-vector based on
148 * destination IP
149 */
150 void FlushNixCache() const;
151
152 /**
153 * Flushes the cache which stores the Ip route
154 * based on the destination IP
155 */
156 void FlushIpRouteCache() const;
157
158 /**
159 * Upon a run-time topology change caches are
160 * flushed and the total number of neighbors is
161 * reset to zero
162 */
164
165 /**
166 * Takes in the source node and dest IP and calls GetNodeByIp,
167 * BFS, accounting for any output interface specified, and finally
168 * BuildNixVector to return the built nix-vector
169 *
170 * \param source Source node
171 * \param dest Destination node address
172 * \param oif Preferred output interface
173 * \returns The NixVector to be used in routing.
174 */
176
177 /**
178 * Checks the cache based on dest IP for the nix-vector
179 * \param address Address to check
180 * \param foundInCache Address found in cache
181 * \returns The NixVector to be used in routing.
182 */
183 Ptr<NixVector> GetNixVectorInCache(const IpAddress& address, bool& foundInCache) const;
184
185 /**
186 * Checks the cache based on dest IP for the IpRoute
187 * \param address Address to check
188 * \returns The cached route.
189 */
191
192 /**
193 * Given a net-device returns all the adjacent net-devices,
194 * essentially getting the neighbors on that channel
195 * \param [in] netDevice the NetDevice attached to the channel.
196 * \param [in] channel the channel to check
197 * \param [out] netDeviceContainer the NetDeviceContainer of the NetDevices in the channel.
198 */
200 Ptr<Channel> channel,
201 NetDeviceContainer& netDeviceContainer) const;
202
203 /**
204 * Iterates through the node list and finds the one
205 * corresponding to the given IpAddress
206 * \param dest destination node IP
207 * \return The node with the specified IP.
208 */
209 Ptr<Node> GetNodeByIp(IpAddress dest) const;
210
211 /**
212 * Iterates through the node list and finds the one
213 * corresponding to the given IpAddress
214 * \param netDevice NetDevice pointer
215 * \return The node with the specified IP.
216 */
218
219 /**
220 * Recurses the T vector, created by BFS and actually builds the nixvector
221 * \param [in] parentVector Parent vector for retracing routes
222 * \param [in] source Source Node index
223 * \param [in] dest Destination Node index
224 * \param [out] nixVector the NixVector to be used for routing
225 * \returns true on success, false otherwise.
226 */
227 bool BuildNixVector(const std::vector<Ptr<Node>>& parentVector,
228 uint32_t source,
229 uint32_t dest,
230 Ptr<NixVector> nixVector) const;
231
232 /**
233 * Simply iterates through the nodes net-devices and determines
234 * how many neighbors the node has.
235 * \param [in] node node pointer
236 * \returns the number of neighbors of m_node.
237 */
239
240 /**
241 * Determine if the NetDevice is bridged
242 * \param nd the NetDevice to check
243 * \returns the bridging NetDevice (or null if the NetDevice is not bridged)
244 */
246
247 /**
248 * Nix index is with respect to the neighbors. The net-device index must be
249 * derived from this
250 * \param [in] node the current node under consideration
251 * \param [in] nodeIndex Nix Node index
252 * \param [out] gatewayIp IP address of the gateway
253 * \returns the index of the NetDevice in the node.
254 */
256 uint32_t nodeIndex,
257 IpAddress& gatewayIp) const;
258
259 /**
260 * \brief Breadth first search algorithm.
261 * \param [in] numberOfNodes total number of nodes
262 * \param [in] source Source Node
263 * \param [in] dest Destination Node
264 * \param [out] parentVector Parent vector for retracing routes
265 * \param [in] oif specific output interface to use from source node, if not null
266 * \returns false if dest not found, true o.w.
267 */
268 bool BFS(uint32_t numberOfNodes,
269 Ptr<Node> source,
270 Ptr<Node> dest,
271 std::vector<Ptr<Node>>& parentVector,
272 Ptr<NetDevice> oif) const;
273
274 /**
275 * \sa Ipv4RoutingProtocol::DoInitialize
276 * \sa Ipv6RoutingProtocol::DoInitialize
277 */
278 void DoInitialize();
279
280 /**
281 * \sa Ipv4RoutingProtocol::DoDispose
282 * \sa Ipv6RoutingProtocol::DoDispose
283 */
284 void DoDispose();
285
286 /// Map of IpAddress to NixVector
287 typedef std::map<IpAddress, Ptr<NixVector>> NixMap_t;
288 /// Map of IpAddress to IpRoute
289 typedef std::map<IpAddress, Ptr<IpRoute>> IpRouteMap_t;
290
291 /// Callback for IPv4 unicast packets to be forwarded
294
295 /// Callback for IPv6 unicast packets to be forwarded
298
299 /// Callback for unicast packets to be forwarded
300 typedef typename std::conditional_t<IsIpv4, UnicastForwardCallbackv4, UnicastForwardCallbackv6>
302
303 /// Callback for IPv4 multicast packets to be forwarded
306
307 /// Callback for IPv6 multicast packets to be forwarded
308 typedef Callback<void,
312 const IpHeader&>
314
315 /// Callback for multicast packets to be forwarded
316 typedef
317 typename std::conditional_t<IsIpv4, MulticastForwardCallbackv4, MulticastForwardCallbackv6>
319
320 /// Callback for packets to be locally delivered
322
323 /// Callback for routing errors (e.g., no route found)
325
326 /* From Ipv4RoutingProtocol and Ipv6RoutingProtocol */
327 /**
328 * \brief Query routing cache for an existing route, for an outbound packet
329 * \param p packet to be routed. Note that this method may modify the packet.
330 * Callers may also pass in a null pointer.
331 * \param header input parameter (used to form key to search for the route)
332 * \param oif Output interface Netdevice. May be zero, or may be bound via
333 * socket options to a particular output interface.
334 * \param sockerr Output parameter; socket errno
335 *
336 * \returns a code that indicates what happened in the lookup
337 *
338 * \sa Ipv4RoutingProtocol::RouteOutput
339 * \sa Ipv6RoutingProtocol::RouteOutput
340 */
342 const IpHeader& header,
343 Ptr<NetDevice> oif,
344 Socket::SocketErrno& sockerr);
345
346 /**
347 * \brief Route an input packet (to be forwarded or locally delivered)
348 * \param p received packet
349 * \param header input parameter used to form a search key for a route
350 * \param idev Pointer to ingress network device
351 * \param ucb Callback for the case in which the packet is to be forwarded
352 * as unicast
353 * \param mcb Callback for the case in which the packet is to be forwarded
354 * as multicast
355 * \param lcb Callback for the case in which the packet is to be locally
356 * delivered
357 * \param ecb Callback to call if there is an error in forwarding
358 *
359 * \returns true if NixVectorRouting class takes responsibility for
360 * forwarding or delivering the packet, false otherwise
361 *
362 * \sa Ipv4RoutingProtocol::RouteInput
363 * \sa Ipv6RoutingProtocol::RouteInput
364 */
365 virtual bool RouteInput(Ptr<const Packet> p,
366 const IpHeader& header,
368 const UnicastForwardCallback& ucb,
369 const MulticastForwardCallback& mcb,
370 const LocalDeliverCallback& lcb,
371 const ErrorCallback& ecb);
372
373 /**
374 * \param interface the index of the interface we are being notified about
375 *
376 * \sa Ipv4RoutingProtocol::NotifyInterfaceUp
377 * \sa Ipv6RoutingProtocol::NotifyInterfaceUp
378 */
379 virtual void NotifyInterfaceUp(uint32_t interface);
380
381 /**
382 * \param interface the index of the interface we are being notified about
383 *
384 * \sa Ipv4RoutingProtocol::NotifyInterfaceDown
385 * \sa Ipv6RoutingProtocol::NotifyInterfaceDown
386 */
387 virtual void NotifyInterfaceDown(uint32_t interface);
388
389 /**
390 * \param interface the index of the interface we are being notified about
391 * \param address a new address being added to an interface
392 *
393 * \sa Ipv4RoutingProtocol::NotifyAddAddress
394 * \sa Ipv6RoutingProtocol::NotifyAddAddress
395 */
396 virtual void NotifyAddAddress(uint32_t interface, IpInterfaceAddress address);
397
398 /**
399 * \param interface the index of the interface we are being notified about
400 * \param address a new address being added to an interface
401 *
402 * \sa Ipv4RoutingProtocol::NotifyRemoveAddress
403 * \sa Ipv6RoutingProtocol::NotifyRemoveAddress
404 */
405 virtual void NotifyRemoveAddress(uint32_t interface, IpInterfaceAddress address);
406
407 /**
408 * \brief Print the Routing Table entries
409 *
410 * \param stream The ostream the Routing table is printed to
411 * \param unit The time unit to be used in the report
412 *
413 * \sa Ipv4RoutingProtocol::PrintRoutingTable
414 * \sa Ipv6RoutingProtocol::PrintRoutingTable
415 */
417 Time::Unit unit = Time::S) const;
418
419 /* From IPv4RoutingProtocol */
420 /**
421 * \brief Typically, invoked directly or indirectly from ns3::Ipv4::SetRoutingProtocol
422 *
423 * \param ipv4 the ipv4 object this routing protocol is being associated with
424 *
425 * \sa Ipv4RoutingProtocol::SetIpv4
426 */
427 virtual void SetIpv4(Ptr<Ip> ipv4);
428
429 /* From IPv6RoutingProtocol */
430 /**
431 * \brief Typically, invoked directly or indirectly from ns3::Ipv6::SetRoutingProtocol
432 *
433 * \param ipv6 the ipv6 object this routing protocol is being associated with
434 *
435 * \sa Ipv6RoutingProtocol::SetIpv6
436 */
437 virtual void SetIpv6(Ptr<Ip> ipv6);
438
439 /**
440 * \brief Notify a new route.
441 *
442 * \param dst destination address
443 * \param mask destination mask
444 * \param nextHop nextHop for this destination
445 * \param interface output interface
446 * \param prefixToUse prefix to use as source with this route
447 *
448 * \sa Ipv6RoutingProtocol::NotifyAddRoute
449 */
450 virtual void NotifyAddRoute(IpAddress dst,
451 Ipv6Prefix mask,
452 IpAddress nextHop,
453 uint32_t interface,
454 IpAddress prefixToUse = IpAddress::GetZero());
455
456 /**
457 * \brief Notify route removing.
458 *
459 * \param dst destination address
460 * \param mask destination mask
461 * \param nextHop nextHop for this destination
462 * \param interface output interface
463 * \param prefixToUse prefix to use as source with this route
464 *
465 * \sa Ipv6RoutingProtocol::NotifyRemoveRoute
466 */
467 virtual void NotifyRemoveRoute(IpAddress dst,
468 Ipv6Prefix mask,
469 IpAddress nextHop,
470 uint32_t interface,
471 IpAddress prefixToUse = IpAddress::GetZero());
472
473 /**
474 * Flushes routing caches if required.
475 */
476 void CheckCacheStateAndFlush() const;
477
478 /**
479 * Build map from IP Address to Node for faster lookup.
480 */
481 void BuildIpAddressToNodeMap() const;
482
483 /**
484 * Flag to mark when caches are dirty and need to be flushed.
485 * Used for lazy cleanup of caches when there are many topology changes.
486 */
487 static bool g_isCacheDirty;
488
489 /**
490 * Nix Epoch, incremented each time a flush is performed.
491 */
493
494 /** Cache stores nix-vectors based on destination ip */
496
497 /** Cache stores IpRoutes based on destination ip */
499
500 Ptr<Ip> m_ip; //!< IP object
501 Ptr<Node> m_node; //!< Node object
502
503 /** Total neighbors used for nix-vector to determine number of bits */
505
506 /**
507 * Mapping of IP address to ns-3 node.
508 *
509 * Used to avoid linear searching of nodes/devices to find a node in
510 * GetNodeByIp() method. NIX vector routing assumes IP addresses
511 * are unique so mapping can be done without duplication.
512 **/
513 typedef std::unordered_map<IpAddress, ns3::Ptr<ns3::Node>, IpAddressHash> IpAddressToNodeMap;
514 static IpAddressToNodeMap g_ipAddressToNodeMap; //!< Address to node map.
515
516 /// Mapping of Ptr<NetDevice> to Ptr<IpInterface>.
517 typedef std::unordered_map<Ptr<NetDevice>, Ptr<IpInterface>> NetDeviceToIpInterfaceMap;
519 g_netdeviceToIpInterfaceMap; //!< NetDevice pointer to IpInterface pointer map
520};
521
522/**
523 * \ingroup nix-vector-routing
524 * Create the typedef Ipv4NixVectorRouting with T as Ipv4RoutingProtocol
525 *
526 * Note: This typedef enables also backwards compatibility with original Ipv4NixVectorRouting.
527 */
529
530/**
531 * \ingroup nix-vector-routing
532 * Create the typedef Ipv6NixVectorRouting with T as Ipv6RoutingProtocol
533 */
535} // namespace ns3
536
537// NOLINTEND(modernize-use-override)
538
539#endif /* NIX_VECTOR_ROUTING_H */
Callback template class.
Definition: callback.h:438
Describes an IPv6 prefix.
Definition: ipv6-address.h:455
holds a vector of ns3::NetDevice pointers
Nix-vector routing protocol.
Callback< void, Ptr< IpRoute >, Ptr< const Packet >, const IpHeader & > UnicastForwardCallbackv4
Callback for IPv4 unicast packets to be forwarded.
std::map< IpAddress, Ptr< IpRoute > > IpRouteMap_t
Map of IpAddress to IpRoute.
void PrintRoutingPath(Ptr< Node > source, IpAddress dest, Ptr< OutputStreamWrapper > stream, Time::Unit unit) const
Print the Routing Path according to Nix Routing.
void BuildIpAddressToNodeMap() const
Build map from IP Address to Node for faster lookup.
Ptr< IpRoute > GetIpRouteInCache(IpAddress address)
Checks the cache based on dest IP for the IpRoute.
virtual void NotifyRemoveRoute(IpAddress dst, Ipv6Prefix mask, IpAddress nextHop, uint32_t interface, IpAddress prefixToUse=IpAddress::GetZero())
Notify route removing.
virtual void NotifyAddRoute(IpAddress dst, Ipv6Prefix mask, IpAddress nextHop, uint32_t interface, IpAddress prefixToUse=IpAddress::GetZero())
Notify a new route.
typename std::conditional_t< IsIpv4, Ipv4InterfaceAddress, Ipv6InterfaceAddress > IpInterfaceAddress
Alias for Ipv4InterfaceAddress and Ipv6InterfaceAddress classes.
bool BFS(uint32_t numberOfNodes, Ptr< Node > source, Ptr< Node > dest, std::vector< Ptr< Node > > &parentVector, Ptr< NetDevice > oif) const
Breadth first search algorithm.
static uint32_t g_epoch
Nix Epoch, incremented each time a flush is performed.
virtual void NotifyInterfaceUp(uint32_t interface)
void GetAdjacentNetDevices(Ptr< NetDevice > netDevice, Ptr< Channel > channel, NetDeviceContainer &netDeviceContainer) const
Given a net-device returns all the adjacent net-devices, essentially getting the neighbors on that ch...
std::conditional_t< IsIpv4, UnicastForwardCallbackv4, UnicastForwardCallbackv6 > UnicastForwardCallback
Callback for unicast packets to be forwarded.
typename std::conditional_t< IsIpv4, Ipv4AddressHash, Ipv6AddressHash > IpAddressHash
Alias for Ipv4AddressHash and Ipv6AddressHash classes.
std::map< IpAddress, Ptr< NixVector > > NixMap_t
Map of IpAddress to NixVector.
NixMap_t m_nixCache
Cache stores nix-vectors based on destination ip.
typename std::conditional_t< IsIpv4, Ipv4Route, Ipv6Route > IpRoute
Alias for Ipv4Route and Ipv6Route classes.
virtual void NotifyInterfaceDown(uint32_t interface)
typename std::conditional_t< IsIpv4, Ipv4Address, Ipv6Address > IpAddress
Alias for Ipv4Address and Ipv6Address classes.
static IpAddressToNodeMap g_ipAddressToNodeMap
Address to node map.
void FlushGlobalNixRoutingCache() const
Called when run-time link topology change occurs which iterates through the node list and flushes any...
Callback< void, Ptr< Ipv4MulticastRoute >, Ptr< const Packet >, const IpHeader & > MulticastForwardCallbackv4
Callback for IPv4 multicast packets to be forwarded.
virtual void SetIpv6(Ptr< Ip > ipv6)
Typically, invoked directly or indirectly from ns3::Ipv6::SetRoutingProtocol.
Callback< void, Ptr< const Packet >, const IpHeader &, Socket::SocketErrno > ErrorCallback
Callback for routing errors (e.g., no route found)
uint32_t m_totalNeighbors
Total neighbors used for nix-vector to determine number of bits.
virtual Ptr< IpRoute > RouteOutput(Ptr< Packet > p, const IpHeader &header, Ptr< NetDevice > oif, Socket::SocketErrno &sockerr)
Query routing cache for an existing route, for an outbound packet.
virtual void SetIpv4(Ptr< Ip > ipv4)
Typically, invoked directly or indirectly from ns3::Ipv4::SetRoutingProtocol.
Ptr< IpInterface > GetInterfaceByNetDevice(Ptr< NetDevice > netDevice) const
Iterates through the node list and finds the one corresponding to the given IpAddress.
uint32_t FindTotalNeighbors(Ptr< Node > node) const
Simply iterates through the nodes net-devices and determines how many neighbors the node has.
virtual void NotifyAddAddress(uint32_t interface, IpInterfaceAddress address)
std::conditional_t< IsIpv4, MulticastForwardCallbackv4, MulticastForwardCallbackv6 > MulticastForwardCallback
Callback for multicast packets to be forwarded.
void FlushIpRouteCache() const
Flushes the cache which stores the Ip route based on the destination IP.
virtual bool RouteInput(Ptr< const Packet > p, const IpHeader &header, Ptr< const NetDevice > idev, const UnicastForwardCallback &ucb, const MulticastForwardCallback &mcb, const LocalDeliverCallback &lcb, const ErrorCallback &ecb)
Route an input packet (to be forwarded or locally delivered)
Ptr< Ip > m_ip
IP object.
Ptr< NixVector > GetNixVector(Ptr< Node > source, IpAddress dest, Ptr< NetDevice > oif) const
Takes in the source node and dest IP and calls GetNodeByIp, BFS, accounting for any output interface ...
typename std::conditional_t< IsIpv4, Ipv4Interface, Ipv6Interface > IpInterface
Alias for Ipv4Interface and Ipv6Interface classes.
typename std::conditional_t< IsIpv4, Ipv4, Ipv6 > Ip
Alias for Ipv4 and Ipv6 classes.
typename std::conditional_t< IsIpv4, Ipv4Header, Ipv6Header > IpHeader
Alias for Ipv4Header and Ipv6Header classes.
bool BuildNixVector(const std::vector< Ptr< Node > > &parentVector, uint32_t source, uint32_t dest, Ptr< NixVector > nixVector) const
Recurses the T vector, created by BFS and actually builds the nixvector.
Callback< void, Ptr< const NetDevice >, Ptr< Ipv6MulticastRoute >, Ptr< const Packet >, const IpHeader & > MulticastForwardCallbackv6
Callback for IPv6 multicast packets to be forwarded.
Ptr< NixVector > GetNixVectorInCache(const IpAddress &address, bool &foundInCache) const
Checks the cache based on dest IP for the nix-vector.
uint32_t FindNetDeviceForNixIndex(Ptr< Node > node, uint32_t nodeIndex, IpAddress &gatewayIp) const
Nix index is with respect to the neighbors.
static NetDeviceToIpInterfaceMap g_netdeviceToIpInterfaceMap
NetDevice pointer to IpInterface pointer map.
void SetNode(Ptr< Node > node)
Set the Node pointer of the node for which this routing protocol is to be placed.
virtual void PrintRoutingTable(Ptr< OutputStreamWrapper > stream, Time::Unit unit=Time::S) const
Print the Routing Table entries.
typename std::conditional_t< IsIpv4, Ipv4L3Protocol, Ipv6L3Protocol > IpL3Protocol
Alias for Ipv4L3Protocol and Ipv4L3Protocol classes.
void ResetTotalNeighbors()
Upon a run-time topology change caches are flushed and the total number of neighbors is reset to zero...
virtual void NotifyRemoveAddress(uint32_t interface, IpInterfaceAddress address)
Callback< void, Ptr< const Packet >, const IpHeader &, uint32_t > LocalDeliverCallback
Callback for packets to be locally delivered.
static TypeId GetTypeId()
The Interface ID of the Global Router interface.
static bool g_isCacheDirty
Flag to mark when caches are dirty and need to be flushed.
Ptr< Node > m_node
Node object.
void CheckCacheStateAndFlush() const
Flushes routing caches if required.
Callback< void, Ptr< const NetDevice >, Ptr< IpRoute >, Ptr< const Packet >, const IpHeader & > UnicastForwardCallbackv6
Callback for IPv6 unicast packets to be forwarded.
std::unordered_map< IpAddress, ns3::Ptr< ns3::Node >, IpAddressHash > IpAddressToNodeMap
Mapping of IP address to ns-3 node.
std::unordered_map< Ptr< NetDevice >, Ptr< IpInterface > > NetDeviceToIpInterfaceMap
Mapping of Ptr<NetDevice> to Ptr<IpInterface>.
Ptr< BridgeNetDevice > NetDeviceIsBridged(Ptr< NetDevice > nd) const
Determine if the NetDevice is bridged.
static constexpr bool IsIpv4
Alias for determining whether the parent is Ipv4RoutingProtocol or Ipv6RoutingProtocol.
IpRouteMap_t m_ipRouteCache
Cache stores IpRoutes based on destination ip.
void FlushNixCache() const
Flushes the cache which stores nix-vector based on destination IP.
Ptr< Node > GetNodeByIp(IpAddress dest) const
Iterates through the node list and finds the one corresponding to the given IpAddress.
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:77
SocketErrno
Enumeration of the possible errors returned by a socket.
Definition: socket.h:84
Unit
The unit to use to interpret a number representing time.
Definition: nstime.h:111
@ S
second
Definition: nstime.h:116
a unique identifier for an interface.
Definition: type-id.h:59
NixVectorRouting< Ipv6RoutingProtocol > Ipv6NixVectorRouting
Create the typedef Ipv6NixVectorRouting with T as Ipv6RoutingProtocol.
NixVectorRouting< Ipv4RoutingProtocol > Ipv4NixVectorRouting
Create the typedef Ipv4NixVectorRouting with T as Ipv4RoutingProtocol.
Every class exported by the ns3 library is enclosed in the ns3 namespace.