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

AODV routing protocol. More...

#include "aodv-routing-protocol.h"

+ Inheritance diagram for ns3::aodv::RoutingProtocol:
+ Collaboration diagram for ns3::aodv::RoutingProtocol:

Public Member Functions

 RoutingProtocol ()
 constructor
 
 ~RoutingProtocol () override
 
int64_t AssignStreams (int64_t stream)
 Assign a fixed random variable stream number to the random variables used by this model.
 
void DoDispose () override
 Destructor implementation.
 
bool GetBroadcastEnable () const
 Get broadcast enable flag.
 
bool GetDestinationOnlyFlag () const
 Get destination only flag.
 
bool GetGratuitousReplyFlag () const
 Get gratuitous reply flag.
 
bool GetHelloEnable () const
 Get hello enable flag.
 
uint32_t GetMaxQueueLen () const
 Get the maximum queue length.
 
Time GetMaxQueueTime () const
 Get maximum queue time.
 
void NotifyAddAddress (uint32_t interface, Ipv4InterfaceAddress address) override
 
void NotifyInterfaceDown (uint32_t interface) override
 
void NotifyInterfaceUp (uint32_t interface) override
 
void NotifyRemoveAddress (uint32_t interface, Ipv4InterfaceAddress address) override
 
void PrintRoutingTable (Ptr< OutputStreamWrapper > stream, Time::Unit unit=Time::S) const override
 Print the Routing Table entries.
 
bool RouteInput (Ptr< const Packet > p, const Ipv4Header &header, Ptr< const NetDevice > idev, const UnicastForwardCallback &ucb, const MulticastForwardCallback &mcb, const LocalDeliverCallback &lcb, const ErrorCallback &ecb) override
 Route an input packet (to be forwarded or locally delivered)
 
Ptr< Ipv4RouteRouteOutput (Ptr< Packet > p, const Ipv4Header &header, Ptr< NetDevice > oif, Socket::SocketErrno &sockerr) override
 Query routing cache for an existing route, for an outbound packet.
 
void SetBroadcastEnable (bool f)
 Set broadcast enable flag.
 
void SetDestinationOnlyFlag (bool f)
 Set destination only flag.
 
void SetGratuitousReplyFlag (bool f)
 Set gratuitous reply flag.
 
void SetHelloEnable (bool f)
 Set hello enable.
 
void SetIpv4 (Ptr< Ipv4 > ipv4) override
 
void SetMaxQueueLen (uint32_t len)
 Set the maximum queue length.
 
void SetMaxQueueTime (Time t)
 Set the maximum queue time.
 
virtual void NotifyAddAddress (uint32_t interface, Ipv4InterfaceAddress address)=0
 
virtual void NotifyInterfaceDown (uint32_t interface)=0
 
virtual void NotifyInterfaceUp (uint32_t interface)=0
 
virtual void NotifyRemoveAddress (uint32_t interface, Ipv4InterfaceAddress address)=0
 
virtual void PrintRoutingTable (Ptr< OutputStreamWrapper > stream, Time::Unit unit=Time::S) const =0
 Print the Routing Table entries.
 
virtual bool RouteInput (Ptr< const Packet > p, const Ipv4Header &header, Ptr< const NetDevice > idev, const UnicastForwardCallback &ucb, const MulticastForwardCallback &mcb, const LocalDeliverCallback &lcb, const ErrorCallback &ecb)=0
 Route an input packet (to be forwarded or locally delivered)
 
virtual Ptr< Ipv4RouteRouteOutput (Ptr< Packet > p, const Ipv4Header &header, Ptr< NetDevice > oif, Socket::SocketErrno &sockerr)=0
 Query routing cache for an existing route, for an outbound packet.
 
virtual void SetIpv4 (Ptr< Ipv4 > ipv4)=0
 
- Public Member Functions inherited from ns3::Object
 Object ()
 Constructor.
 
 ~Object () override
 Destructor.
 
void AggregateObject (Ptr< Object > other)
 Aggregate two Objects together.
 
void Dispose ()
 Dispose of this Object.
 
AggregateIterator GetAggregateIterator () const
 Get an iterator to the Objects aggregated to this one.
 
TypeId GetInstanceTypeId () const override
 Get the most derived TypeId for this Object.
 
template<typename T >
Ptr< T > GetObject () const
 Get a pointer to the requested aggregated Object.
 
template<>
Ptr< ObjectGetObject () const
 Specialization of () for objects of type ns3::Object.
 
template<typename T >
Ptr< T > GetObject (TypeId tid) const
 Get a pointer to the requested aggregated Object by TypeId.
 
template<>
Ptr< ObjectGetObject (TypeId tid) const
 Specialization of (TypeId tid) for objects of type ns3::Object.
 
void Initialize ()
 Invoke DoInitialize on all Objects aggregated to this one.
 
bool IsInitialized () const
 Check if the object has been initialized.
 
void UnidirectionalAggregateObject (Ptr< Object > other)
 Aggregate an Object to another Object.
 
- Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter >
 SimpleRefCount ()
 Default constructor.
 
 SimpleRefCount (const SimpleRefCount &o)
 Copy constructor.
 
uint32_t GetReferenceCount () const
 Get the reference count of the object.
 
SimpleRefCountoperator= (const SimpleRefCount &o)
 Assignment operator.
 
void Ref () const
 Increment the reference count.
 
void Unref () const
 Decrement the reference count.
 
- Public Member Functions inherited from ns3::ObjectBase
virtual ~ObjectBase ()
 Virtual destructor.
 
void GetAttribute (std::string name, AttributeValue &value) const
 Get the value of an attribute, raising fatal errors if unsuccessful.
 
bool GetAttributeFailSafe (std::string name, AttributeValue &value) const
 Get the value of an attribute without raising errors.
 
virtual TypeId GetInstanceTypeId () const =0
 Get the most derived TypeId for this Object.
 
void SetAttribute (std::string name, const AttributeValue &value)
 Set a single attribute, raising fatal errors if unsuccessful.
 
bool SetAttributeFailSafe (std::string name, const AttributeValue &value)
 Set a single attribute without raising errors.
 
bool TraceConnect (std::string name, std::string context, const CallbackBase &cb)
 Connect a TraceSource to a Callback with a context.
 
bool TraceConnectWithoutContext (std::string name, const CallbackBase &cb)
 Connect a TraceSource to a Callback without a context.
 
bool TraceDisconnect (std::string name, std::string context, const CallbackBase &cb)
 Disconnect from a TraceSource a Callback previously connected with a context.
 
bool TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb)
 Disconnect from a TraceSource a Callback previously connected without a context.
 

Static Public Member Functions

static TypeId GetTypeId ()
 Get the type ID.
 
- Static Public Member Functions inherited from ns3::Ipv4RoutingProtocol
static TypeId GetTypeId ()
 Get the type ID.
 
- Static Public Member Functions inherited from ns3::Object
static TypeId GetTypeId ()
 Register this type.
 
- Static Public Member Functions inherited from ns3::ObjectBase
static TypeId GetTypeId ()
 Get the type ID.
 

Static Public Attributes

static const uint32_t AODV_PORT = 654
 UDP Port for AODV control traffic.
 

Protected Member Functions

void DoInitialize () override
 Initialize() implementation.
 
- Protected Member Functions inherited from ns3::Object
 Object (const Object &o)
 Copy an Object.
 
virtual void DoDispose ()
 Destructor implementation.
 
virtual void DoInitialize ()
 Initialize() implementation.
 
virtual void NotifyNewAggregate ()
 Notify all Objects aggregated to this one of a new Object being aggregated.
 
- Protected Member Functions inherited from ns3::ObjectBase
void ConstructSelf (const AttributeConstructionList &attributes)
 Complete construction of ObjectBase; invoked by derived classes.
 
virtual void NotifyConstructionCompleted ()
 Notifier called once the ObjectBase is fully constructed.
 

Private Member Functions

void AckTimerExpire (Ipv4Address neighbor, Time blacklistTimeout)
 Mark link to neighbor node as unidirectional for blacklistTimeout.
 
void DeferredRouteOutput (Ptr< const Packet > p, const Ipv4Header &header, UnicastForwardCallback ucb, ErrorCallback ecb)
 Queue packet and send route request.
 
Ptr< SocketFindSocketWithInterfaceAddress (Ipv4InterfaceAddress iface) const
 Find unicast socket with local interface address iface.
 
Ptr< SocketFindSubnetBroadcastSocketWithInterfaceAddress (Ipv4InterfaceAddress iface) const
 Find subnet directed broadcast socket with local interface address iface.
 
bool Forwarding (Ptr< const Packet > p, const Ipv4Header &header, UnicastForwardCallback ucb, ErrorCallback ecb)
 If route exists and is valid, forward packet.
 
void HelloTimerExpire ()
 Schedule next send of hello message.
 
bool IsMyOwnAddress (Ipv4Address src)
 Test whether the provided address is assigned to an interface on this node.
 
Ptr< Ipv4RouteLoopbackRoute (const Ipv4Header &header, Ptr< NetDevice > oif) const
 Create loopback route for given header.
 
void NotifyTxError (WifiMacDropReason reason, Ptr< const WifiMpdu > mpdu)
 Notify that an MPDU was dropped.
 
void ProcessHello (const RrepHeader &rrepHeader, Ipv4Address receiverIfaceAddr)
 Process hello message.
 
void RerrRateLimitTimerExpire ()
 Reset RERR count and schedule RERR rate limit timer with delay 1 sec.
 
void RouteRequestTimerExpire (Ipv4Address dst)
 Handle route discovery process.
 
void RreqRateLimitTimerExpire ()
 Reset RREQ count and schedule RREQ rate limit timer with delay 1 sec.
 
void ScheduleRreqRetry (Ipv4Address dst)
 Repeated attempts by a source node at route discovery for a single destination use the expanding ring search technique.
 
void SendTo (Ptr< Socket > socket, Ptr< Packet > packet, Ipv4Address destination)
 Send packet to destination socket.
 
void Start ()
 Start protocol operation.
 
bool UpdateRouteLifeTime (Ipv4Address addr, Time lt)
 Set lifetime field in routing table entry to the maximum of existing lifetime and lt, if the entry exists.
 
void UpdateRouteToNeighbor (Ipv4Address sender, Ipv4Address receiver)
 Update neighbor record.
 
Receive control packets
void RecvAodv (Ptr< Socket > socket)
 Receive and process control packet.
 
void RecvRequest (Ptr< Packet > p, Ipv4Address receiver, Ipv4Address src)
 Receive RREQ.
 
void RecvReply (Ptr< Packet > p, Ipv4Address my, Ipv4Address src)
 Receive RREP.
 
void RecvReplyAck (Ipv4Address neighbor)
 Receive RREP_ACK.
 
void RecvError (Ptr< Packet > p, Ipv4Address src)
 Receive RERR.
 
Send
void SendPacketFromQueue (Ipv4Address dst, Ptr< Ipv4Route > route)
 Forward packet from route request queue.
 
void SendHello ()
 Send hello.
 
void SendRequest (Ipv4Address dst)
 Send RREQ.
 
void SendReply (const RreqHeader &rreqHeader, const RoutingTableEntry &toOrigin)
 Send RREP.
 
void SendReplyByIntermediateNode (RoutingTableEntry &toDst, RoutingTableEntry &toOrigin, bool gratRep)
 Send RREP by intermediate node.
 
void SendReplyAck (Ipv4Address neighbor)
 Send RREP_ACK.
 
void SendRerrWhenBreaksLinkToNextHop (Ipv4Address nextHop)
 Initiate RERR.
 
void SendRerrMessage (Ptr< Packet > packet, std::vector< Ipv4Address > precursors)
 Forward RERR.
 
void SendRerrWhenNoRouteToForward (Ipv4Address dst, uint32_t dstSeqNo, Ipv4Address origin)
 Send RERR message when no route to forward input packet.
 

Private Attributes

Time m_activeRouteTimeout
 Period of time during which the route is considered to be valid.
 
std::map< Ipv4Address, Timerm_addressReqTimer
 Map IP address + RREQ timer.
 
uint32_t m_allowedHelloLoss
 Number of hello messages which may be loss for valid link.
 
Time m_blackListTimeout
 Time for which the node is put into the blacklist.
 
Time m_deletePeriod
 DeletePeriod is intended to provide an upper bound on the time for which an upstream node A can have a neighbor B as an active next hop for destination D, while B has invalidated the route to D.
 
bool m_destinationOnly
 Indicates only the destination may respond to this RREQ.
 
DuplicatePacketDetection m_dpd
 Handle duplicated broadcast/multicast packets.
 
bool m_enableBroadcast
 Indicates whether a a broadcast data packets forwarding enable.
 
bool m_enableHello
 Indicates whether a hello messages enable.
 
bool m_gratuitousReply
 Indicates whether a gratuitous RREP should be unicast to the node originated route discovery.
 
Time m_helloInterval
 Every HelloInterval the node checks whether it has sent a broadcast within the last HelloInterval.
 
Timer m_htimer
 Hello timer.
 
Ptr< Ipv4m_ipv4
 IP protocol.
 
Time m_lastBcastTime
 Keep track of the last bcast time.
 
Ptr< NetDevicem_lo
 Loopback device used to defer RREQ until packet will be fully formed.
 
uint32_t m_maxQueueLen
 The maximum number of packets that we allow a routing protocol to buffer.
 
Time m_maxQueueTime
 The maximum period of time that a routing protocol is allowed to buffer a packet for.
 
Time m_myRouteTimeout
 Value of lifetime field in RREP generating by this node.
 
Neighbors m_nb
 Handle neighbors.
 
uint32_t m_netDiameter
 Net diameter measures the maximum possible number of hops between two nodes in the network.
 
Time m_netTraversalTime
 Estimate of the average net traversal time.
 
Time m_nextHopWait
 Period of our waiting for the neighbour's RREP_ACK.
 
Time m_nodeTraversalTime
 NodeTraversalTime is a conservative estimate of the average one hop traversal time for packets and should include queuing delays, interrupt processing times and transfer times.
 
Time m_pathDiscoveryTime
 Estimate of maximum time needed to find route in network.
 
RequestQueue m_queue
 A "drop-front" queue used by the routing layer to buffer packets to which it does not have a route.
 
uint32_t m_requestId
 Broadcast ID.
 
uint16_t m_rerrCount
 Number of RERRs used for RERR rate control.
 
uint16_t m_rerrRateLimit
 Maximum number of REER per second.
 
Timer m_rerrRateLimitTimer
 RERR rate limit timer.
 
RoutingTable m_routingTable
 Routing table.
 
uint16_t m_rreqCount
 Number of RREQs used for RREQ rate control.
 
IdCache m_rreqIdCache
 Handle duplicated RREQ.
 
uint16_t m_rreqRateLimit
 Maximum number of RREQ per second.
 
Timer m_rreqRateLimitTimer
 RREQ rate limit timer.
 
uint32_t m_rreqRetries
 Maximum number of retransmissions of RREQ with TTL = NetDiameter to discover a route.
 
uint32_t m_seqNo
 Request sequence number.
 
std::map< Ptr< Socket >, Ipv4InterfaceAddressm_socketAddresses
 Raw unicast socket per each IP interface, map socket -> iface address (IP + mask)
 
std::map< Ptr< Socket >, Ipv4InterfaceAddressm_socketSubnetBroadcastAddresses
 Raw subnet directed broadcast socket per each IP interface, map socket -> iface address (IP.
 
uint16_t m_timeoutBuffer
 Provide a buffer for the timeout.
 
uint16_t m_ttlIncrement
 TTL increment for each attempt using the expanding ring search for RREQ dissemination.
 
uint16_t m_ttlStart
 Initial TTL value for RREQ.
 
uint16_t m_ttlThreshold
 Maximum TTL value for expanding ring search, TTL = NetDiameter is used beyond this value.
 
Ptr< UniformRandomVariablem_uniformRandomVariable
 Provides uniform random variables.
 

Additional Inherited Members

- Public Types inherited from ns3::Ipv4RoutingProtocol
typedef Callback< void, Ptr< const Packet >, const Ipv4Header &, Socket::SocketErrnoErrorCallback
 Callback for routing errors (e.g., no route found)
 
typedef Callback< void, Ptr< const Packet >, const Ipv4Header &, uint32_tLocalDeliverCallback
 Callback for packets to be locally delivered.
 
typedef Callback< void, Ptr< Ipv4MulticastRoute >, Ptr< const Packet >, const Ipv4Header & > MulticastForwardCallback
 Callback for multicast packets to be forwarded.
 
typedef Callback< void, Ptr< Ipv4Route >, Ptr< const Packet >, const Ipv4Header & > UnicastForwardCallback
 Callback for unicast packets to be forwarded.
 

Detailed Description

AODV routing protocol.

Config Paths

ns3::aodv::RoutingProtocol is accessible through the following paths with Config::Set and Config::Connect:

  • "/NodeList/[i]/$ns3::aodv::RoutingProtocol"

Attributes

  • ActiveRouteTimeout: Period of time during which the route is considered to be valid
    • Set with class: ns3::TimeValue
    • Underlying type: Time +9.22337e+18ns:+9.22337e+18ns
    • Initial value: +3e+09ns
    • Flags: constructwriteread
  • AllowedHelloLoss: Number of hello messages which may be loss for valid link.
    • Set with class: ns3::UintegerValue
    • Underlying type: uint16_t 0:65535
    • Initial value: 2
    • Flags: constructwriteread
  • BlackListTimeout: Time for which the node is put into the blacklist = RreqRetries * NetTraversalTime
    • Set with class: ns3::TimeValue
    • Underlying type: Time +9.22337e+18ns:+9.22337e+18ns
    • Initial value: +5.6e+09ns
    • Flags: constructwriteread
  • DeletePeriod: DeletePeriod is intended to provide an upper bound on the time for which an upstream node A can have a neighbor B as an active next hop for destination D, while B has invalidated the route to D. = 5 * max (HelloInterval, ActiveRouteTimeout)
    • Set with class: ns3::TimeValue
    • Underlying type: Time +9.22337e+18ns:+9.22337e+18ns
    • Initial value: +1.5e+10ns
    • Flags: constructwriteread
  • DestinationOnly: Indicates only the destination may respond to this RREQ.
    • Set with class: ns3::BooleanValue
    • Underlying type: bool
    • Initial value: false
    • Flags: constructwriteread
  • EnableBroadcast: Indicates whether a broadcast data packets forwarding enable.
    • Set with class: ns3::BooleanValue
    • Underlying type: bool
    • Initial value: true
    • Flags: constructwriteread
  • EnableHello: Indicates whether a hello messages enable.
    • Set with class: ns3::BooleanValue
    • Underlying type: bool
    • Initial value: true
    • Flags: constructwriteread
  • GratuitousReply: Indicates whether a gratuitous RREP should be unicast to the node originated route discovery.
    • Set with class: ns3::BooleanValue
    • Underlying type: bool
    • Initial value: true
    • Flags: constructwriteread
  • HelloInterval: HELLO messages emission interval.
    • Set with class: ns3::TimeValue
    • Underlying type: Time +9.22337e+18ns:+9.22337e+18ns
    • Initial value: +1e+09ns
    • Flags: constructwriteread
  • MaxQueueLen: Maximum number of packets that we allow a routing protocol to buffer.
    • Set with class: ns3::UintegerValue
    • Underlying type: uint32_t 0:4294967295
    • Initial value: 64
    • Flags: constructwriteread
  • MaxQueueTime: Maximum time packets can be queued (in seconds)
    • Set with class: ns3::TimeValue
    • Underlying type: Time +9.22337e+18ns:+9.22337e+18ns
    • Initial value: +3e+10ns
    • Flags: constructwriteread
  • MyRouteTimeout: Value of lifetime field in RREP generating by this node = 2 * max(ActiveRouteTimeout, PathDiscoveryTime)
    • Set with class: ns3::TimeValue
    • Underlying type: Time +9.22337e+18ns:+9.22337e+18ns
    • Initial value: +1.12e+10ns
    • Flags: constructwriteread
  • NetDiameter: Net diameter measures the maximum possible number of hops between two nodes in the network
    • Set with class: ns3::UintegerValue
    • Underlying type: uint32_t 0:4294967295
    • Initial value: 35
    • Flags: constructwriteread
  • NetTraversalTime: Estimate of the average net traversal time = 2 * NodeTraversalTime * NetDiameter
    • Set with class: ns3::TimeValue
    • Underlying type: Time +9.22337e+18ns:+9.22337e+18ns
    • Initial value: +2.8e+09ns
    • Flags: constructwriteread
  • NextHopWait: Period of our waiting for the neighbour's RREP_ACK = 10 ms + NodeTraversalTime
    • Set with class: ns3::TimeValue
    • Underlying type: Time +9.22337e+18ns:+9.22337e+18ns
    • Initial value: +5e+07ns
    • Flags: constructwriteread
  • NodeTraversalTime: Conservative estimate of the average one hop traversal time for packets and should include queuing delays, interrupt processing times and transfer times.
    • Set with class: ns3::TimeValue
    • Underlying type: Time +9.22337e+18ns:+9.22337e+18ns
    • Initial value: +4e+07ns
    • Flags: constructwriteread
  • PathDiscoveryTime: Estimate of maximum time needed to find route in network = 2 * NetTraversalTime
    • Set with class: ns3::TimeValue
    • Underlying type: Time +9.22337e+18ns:+9.22337e+18ns
    • Initial value: +5.6e+09ns
    • Flags: constructwriteread
  • RerrRateLimit: Maximum number of RERR per second.
    • Set with class: ns3::UintegerValue
    • Underlying type: uint32_t 0:4294967295
    • Initial value: 10
    • Flags: constructwriteread
  • RreqRateLimit: Maximum number of RREQ per second.
    • Set with class: ns3::UintegerValue
    • Underlying type: uint32_t 0:4294967295
    • Initial value: 10
    • Flags: constructwriteread
  • RreqRetries: Maximum number of retransmissions of RREQ to discover a route
    • Set with class: ns3::UintegerValue
    • Underlying type: uint32_t 0:4294967295
    • Initial value: 2
    • Flags: constructwriteread
  • TimeoutBuffer: Provide a buffer for the timeout.
    • Set with class: ns3::UintegerValue
    • Underlying type: uint16_t 0:65535
    • Initial value: 2
    • Flags: constructwriteread
  • TtlIncrement: TTL increment for each attempt using the expanding ring search for RREQ dissemination.
    • Set with class: ns3::UintegerValue
    • Underlying type: uint16_t 0:65535
    • Initial value: 2
    • Flags: constructwriteread
  • TtlStart: Initial TTL value for RREQ.
    • Set with class: ns3::UintegerValue
    • Underlying type: uint16_t 0:65535
    • Initial value: 1
    • Flags: constructwriteread
  • TtlThreshold: Maximum TTL value for expanding ring search, TTL = NetDiameter is used beyond this value.
    • Set with class: ns3::UintegerValue
    • Underlying type: uint16_t 0:65535
    • Initial value: 7
    • Flags: constructwriteread
  • UniformRv: Access to the underlying UniformRandomVariable

No TraceSources are defined for this type.
Size of this type is 824 bytes (on a 64-bit architecture).

Definition at line 58 of file aodv-routing-protocol.h.

Constructor & Destructor Documentation

◆ RoutingProtocol()

ns3::aodv::RoutingProtocol::RoutingProtocol ( )

constructor

Definition at line 145 of file aodv-routing-protocol.cc.

References m_nb, ns3::MakeCallback(), SendRerrWhenBreaksLinkToNextHop(), and ns3::aodv::Neighbors::SetCallback().

+ Here is the call graph for this function:

◆ ~RoutingProtocol()

ns3::aodv::RoutingProtocol::~RoutingProtocol ( )
override

Definition at line 357 of file aodv-routing-protocol.cc.

Member Function Documentation

◆ AckTimerExpire()

void ns3::aodv::RoutingProtocol::AckTimerExpire ( Ipv4Address  neighbor,
Time  blacklistTimeout 
)
private

Mark link to neighbor node as unidirectional for blacklistTimeout.

Parameters
neighborthe IP address of the neighbor node
blacklistTimeoutthe black list timeout time

Definition at line 1986 of file aodv-routing-protocol.cc.

References m_routingTable, ns3::aodv::RoutingTable::MarkLinkAsUnidirectional(), and NS_LOG_FUNCTION.

Referenced by SendReplyByIntermediateNode().

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

◆ AssignStreams()

int64_t ns3::aodv::RoutingProtocol::AssignStreams ( int64_t  stream)

Assign a fixed random variable stream number to the random variables used by this model.

Return the number of streams (possibly zero) that have been assigned.

Parameters
streamfirst stream index to use
Returns
the number of stream indices assigned by this model

Definition at line 393 of file aodv-routing-protocol.cc.

References m_uniformRandomVariable, NS_LOG_FUNCTION, and ns3::RandomVariableStream::SetStream().

+ Here is the call graph for this function:

◆ DeferredRouteOutput()

void ns3::aodv::RoutingProtocol::DeferredRouteOutput ( Ptr< const Packet p,
const Ipv4Header header,
UnicastForwardCallback  ucb,
ErrorCallback  ecb 
)
private

Queue packet and send route request.

Parameters
pthe packet to route
headerthe IP header
ucbthe UnicastForwardCallback function
ecbthe ErrorCallback function

Definition at line 469 of file aodv-routing-protocol.cc.

References ns3::aodv::RequestQueue::Enqueue(), ns3::Ipv4Header::GetDestination(), ns3::aodv::RoutingTableEntry::GetFlag(), ns3::Ipv4Header::GetProtocol(), ns3::aodv::IN_SEARCH, ns3::aodv::RoutingTable::LookupRoute(), m_queue, m_routingTable, NS_ASSERT, NS_LOG_FUNCTION, NS_LOG_LOGIC, and SendRequest().

Referenced by RouteInput().

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

◆ DoDispose()

void ns3::aodv::RoutingProtocol::DoDispose ( )
overridevirtual

Destructor implementation.

This method is called by Dispose() or by the Object's destructor, whichever comes first.

Subclasses are expected to implement their real destruction code in an overridden version of this method and chain up to their parent's implementation once they are done. i.e, for simplicity, the destructor of every subclass should be empty and its content should be moved to the associated DoDispose() method.

It is safe to call GetObject() from within this method.

Reimplemented from ns3::Object.

Definition at line 362 of file aodv-routing-protocol.cc.

References ns3::Object::DoDispose(), m_ipv4, m_socketAddresses, and m_socketSubnetBroadcastAddresses.

+ Here is the call graph for this function:

◆ DoInitialize()

void ns3::aodv::RoutingProtocol::DoInitialize ( )
overrideprotectedvirtual

Initialize() implementation.

This method is called only once by Initialize(). If the user calls Initialize() multiple times, DoInitialize() is called only the first time.

Subclasses are expected to override this method and chain up to their parent's implementation once they are done. It is safe to call GetObject() and AggregateObject() from within this method.

Reimplemented from ns3::Object.

Definition at line 2287 of file aodv-routing-protocol.cc.

References ns3::Object::DoInitialize(), ns3::UniformRandomVariable::GetInteger(), HelloTimerExpire(), m_enableHello, m_htimer, m_uniformRandomVariable, ns3::MilliSeconds(), NS_LOG_DEBUG, NS_LOG_FUNCTION, ns3::Timer::Schedule(), and ns3::Timer::SetFunction().

+ Here is the call graph for this function:

◆ FindSocketWithInterfaceAddress()

Ptr< Socket > ns3::aodv::RoutingProtocol::FindSocketWithInterfaceAddress ( Ipv4InterfaceAddress  iface) const
private

Find unicast socket with local interface address iface.

Parameters
ifacethe interface
Returns
the socket associated with the interface

Definition at line 2251 of file aodv-routing-protocol.cc.

References m_socketAddresses, and NS_LOG_FUNCTION.

Referenced by NotifyAddAddress(), NotifyInterfaceDown(), NotifyRemoveAddress(), RecvReply(), SendReply(), SendReplyAck(), SendReplyByIntermediateNode(), SendRerrMessage(), and SendRerrWhenNoRouteToForward().

+ Here is the caller graph for this function:

◆ FindSubnetBroadcastSocketWithInterfaceAddress()

Ptr< Socket > ns3::aodv::RoutingProtocol::FindSubnetBroadcastSocketWithInterfaceAddress ( Ipv4InterfaceAddress  iface) const
private

Find subnet directed broadcast socket with local interface address iface.

Parameters
ifacethe interface
Returns
the socket associated with the interface

Definition at line 2268 of file aodv-routing-protocol.cc.

References m_socketSubnetBroadcastAddresses, and NS_LOG_FUNCTION.

Referenced by NotifyInterfaceDown(), and NotifyRemoveAddress().

+ Here is the caller graph for this function:

◆ Forwarding()

bool ns3::aodv::RoutingProtocol::Forwarding ( Ptr< const Packet p,
const Ipv4Header header,
UnicastForwardCallback  ucb,
ErrorCallback  ecb 
)
private

If route exists and is valid, forward packet.

Parameters
pthe packet to route
headerthe IP header
ucbthe UnicastForwardCallback function
ecbthe ErrorCallback function
Returns
true if forwarded

Definition at line 642 of file aodv-routing-protocol.cc.

References ns3::Ipv4Header::GetDestination(), ns3::aodv::RoutingTableEntry::GetFlag(), ns3::aodv::RoutingTableEntry::GetNextHop(), ns3::aodv::RoutingTableEntry::GetRoute(), ns3::aodv::RoutingTableEntry::GetSeqNo(), ns3::Ipv4Header::GetSource(), ns3::aodv::RoutingTableEntry::GetValidSeqNo(), ns3::aodv::RoutingTable::LookupRoute(), m_activeRouteTimeout, m_nb, m_routingTable, NS_LOG_DEBUG, NS_LOG_FUNCTION, NS_LOG_LOGIC, ns3::aodv::RoutingTable::Purge(), SendRerrWhenNoRouteToForward(), ns3::aodv::Neighbors::Update(), UpdateRouteLifeTime(), and ns3::aodv::VALID.

Referenced by RouteInput().

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

◆ GetBroadcastEnable()

bool ns3::aodv::RoutingProtocol::GetBroadcastEnable ( ) const
inline

Get broadcast enable flag.

Returns
the broadcast enable flag

Definition at line 191 of file aodv-routing-protocol.h.

References m_enableBroadcast.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

◆ GetDestinationOnlyFlag()

bool ns3::aodv::RoutingProtocol::GetDestinationOnlyFlag ( ) const
inline

Get destination only flag.

Returns
the destination only flag

Definition at line 128 of file aodv-routing-protocol.h.

References m_destinationOnly.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

◆ GetGratuitousReplyFlag()

bool ns3::aodv::RoutingProtocol::GetGratuitousReplyFlag ( ) const
inline

Get gratuitous reply flag.

Returns
the gratuitous reply flag

Definition at line 146 of file aodv-routing-protocol.h.

References m_gratuitousReply.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

◆ GetHelloEnable()

bool ns3::aodv::RoutingProtocol::GetHelloEnable ( ) const
inline

Get hello enable flag.

Returns
the enable hello flag

Definition at line 173 of file aodv-routing-protocol.h.

References m_enableHello.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

◆ GetMaxQueueLen()

uint32_t ns3::aodv::RoutingProtocol::GetMaxQueueLen ( ) const
inline

Get the maximum queue length.

Returns
the maximum queue length

Definition at line 113 of file aodv-routing-protocol.h.

References m_maxQueueLen.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

◆ GetMaxQueueTime()

Time ns3::aodv::RoutingProtocol::GetMaxQueueTime ( ) const
inline

Get maximum queue time.

Returns
the maximum queue time

Definition at line 98 of file aodv-routing-protocol.h.

References m_maxQueueTime.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

◆ GetTypeId()

◆ HelloTimerExpire()

void ns3::aodv::RoutingProtocol::HelloTimerExpire ( )
private

Schedule next send of hello message.

Definition at line 1950 of file aodv-routing-protocol.cc.

References ns3::Timer::Cancel(), m_helloInterval, m_htimer, m_lastBcastTime, ns3::Simulator::Now(), NS_LOG_DEBUG, NS_LOG_FUNCTION, ns3::Timer::Schedule(), ns3::Seconds(), and SendHello().

Referenced by DoInitialize().

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

◆ IsMyOwnAddress()

bool ns3::aodv::RoutingProtocol::IsMyOwnAddress ( Ipv4Address  src)
private

Test whether the provided address is assigned to an interface on this node.

Parameters
srcthe source IP address
Returns
true if the IP address is the node's IP address

Definition at line 979 of file aodv-routing-protocol.cc.

References ns3::Ipv4InterfaceAddress::GetLocal(), m_socketAddresses, and NS_LOG_FUNCTION.

Referenced by RecvReply(), RecvRequest(), and RouteInput().

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

◆ LoopbackRoute()

Ptr< Ipv4Route > ns3::aodv::RoutingProtocol::LoopbackRoute ( const Ipv4Header header,
Ptr< NetDevice oif 
) const
private

Create loopback route for given header.

Parameters
headerthe IP header
oifthe output interface net device
Returns
the route

Definition at line 994 of file aodv-routing-protocol.cc.

References ns3::Ipv4Header::GetDestination(), m_ipv4, m_lo, m_socketAddresses, NS_ASSERT, NS_ASSERT_MSG, and NS_LOG_FUNCTION.

Referenced by RouteOutput().

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

◆ NotifyAddAddress()

void ns3::aodv::RoutingProtocol::NotifyAddAddress ( uint32_t  interface,
Ipv4InterfaceAddress  address 
)
overridevirtual
Parameters
interfacethe index of the interface we are being notified about
addressa new address being added to an interface

Protocols are expected to implement this method to be notified whenever a new address is added to an interface. Typically used to add a 'network route' on an interface. Can be invoked on an up or down interface.

Implements ns3::Ipv4RoutingProtocol.

Definition at line 847 of file aodv-routing-protocol.cc.

References ns3::aodv::RoutingTable::AddRoute(), AODV_PORT, ns3::Socket::CreateSocket(), FindSocketWithInterfaceAddress(), ns3::Ipv4InterfaceAddress::GetBroadcast(), ns3::Ipv4InterfaceAddress::GetLocal(), ns3::Simulator::GetMaximumSimulationTime(), ns3::UdpSocketFactory::GetTypeId(), m_ipv4, m_routingTable, m_socketAddresses, m_socketSubnetBroadcastAddresses, ns3::MakeCallback(), NS_ASSERT, NS_LOG_FUNCTION, NS_LOG_LOGIC, and RecvAodv().

+ Here is the call graph for this function:

◆ NotifyInterfaceDown()

void ns3::aodv::RoutingProtocol::NotifyInterfaceDown ( uint32_t  interface)
overridevirtual
Parameters
interfacethe index of the interface we are being notified about

Protocols are expected to implement this method to be notified of the state change of an interface in a node.

Implements ns3::Ipv4RoutingProtocol.

Definition at line 804 of file aodv-routing-protocol.cc.

References ns3::Timer::Cancel(), ns3::aodv::Neighbors::Clear(), ns3::aodv::RoutingTable::Clear(), ns3::aodv::Neighbors::DelArpCache(), ns3::aodv::RoutingTable::DeleteAllRoutesFromInterface(), FindSocketWithInterfaceAddress(), FindSubnetBroadcastSocketWithInterfaceAddress(), m_htimer, m_ipv4, m_nb, m_routingTable, m_socketAddresses, m_socketSubnetBroadcastAddresses, ns3::MakeCallback(), NotifyTxError(), NS_ASSERT, NS_LOG_FUNCTION, and NS_LOG_LOGIC.

+ Here is the call graph for this function:

◆ NotifyInterfaceUp()

void ns3::aodv::RoutingProtocol::NotifyInterfaceUp ( uint32_t  interface)
overridevirtual
Parameters
interfacethe index of the interface we are being notified about

Protocols are expected to implement this method to be notified of the state change of an interface in a node.

Implements ns3::Ipv4RoutingProtocol.

Definition at line 730 of file aodv-routing-protocol.cc.

References ns3::aodv::Neighbors::AddArpCache(), ns3::aodv::RoutingTable::AddRoute(), AODV_PORT, ns3::Socket::CreateSocket(), ns3::Ipv4InterfaceAddress::GetBroadcast(), ns3::Ipv4InterfaceAddress::GetLocal(), ns3::Simulator::GetMaximumSimulationTime(), ns3::UdpSocketFactory::GetTypeId(), m_ipv4, m_nb, m_routingTable, m_socketAddresses, m_socketSubnetBroadcastAddresses, ns3::MakeCallback(), NotifyTxError(), NS_ASSERT, NS_LOG_FUNCTION, NS_LOG_WARN, and RecvAodv().

+ Here is the call graph for this function:

◆ NotifyRemoveAddress()

void ns3::aodv::RoutingProtocol::NotifyRemoveAddress ( uint32_t  interface,
Ipv4InterfaceAddress  address 
)
overridevirtual
Parameters
interfacethe index of the interface we are being notified about
addressa new address being added to an interface

Protocols are expected to implement this method to be notified whenever a new address is removed from an interface. Typically used to remove the 'network route' of an interface. Can be invoked on an up or down interface.

Implements ns3::Ipv4RoutingProtocol.

Definition at line 907 of file aodv-routing-protocol.cc.

References ns3::aodv::RoutingTable::AddRoute(), AODV_PORT, ns3::Timer::Cancel(), ns3::aodv::Neighbors::Clear(), ns3::aodv::RoutingTable::Clear(), ns3::Socket::CreateSocket(), ns3::aodv::RoutingTable::DeleteAllRoutesFromInterface(), FindSocketWithInterfaceAddress(), FindSubnetBroadcastSocketWithInterfaceAddress(), ns3::Ipv4InterfaceAddress::GetBroadcast(), ns3::Ipv4InterfaceAddress::GetLocal(), ns3::Simulator::GetMaximumSimulationTime(), ns3::UdpSocketFactory::GetTypeId(), m_htimer, m_ipv4, m_nb, m_routingTable, m_socketAddresses, m_socketSubnetBroadcastAddresses, ns3::MakeCallback(), NS_ASSERT, NS_LOG_FUNCTION, NS_LOG_LOGIC, and RecvAodv().

+ Here is the call graph for this function:

◆ NotifyTxError()

void ns3::aodv::RoutingProtocol::NotifyTxError ( WifiMacDropReason  reason,
Ptr< const WifiMpdu mpdu 
)
private

Notify that an MPDU was dropped.

Parameters
reasonthe reason why the MPDU was dropped
mpduthe dropped MPDU

Definition at line 798 of file aodv-routing-protocol.cc.

References ns3::aodv::Neighbors::GetTxErrorCallback(), and m_nb.

Referenced by NotifyInterfaceDown(), and NotifyInterfaceUp().

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

◆ PrintRoutingTable()

void ns3::aodv::RoutingProtocol::PrintRoutingTable ( Ptr< OutputStreamWrapper stream,
Time::Unit  unit = Time::S 
) const
overridevirtual

Print the Routing Table entries.

Parameters
streamThe ostream the Routing table is printed to
unitThe time unit to be used in the report

Implements ns3::Ipv4RoutingProtocol.

Definition at line 381 of file aodv-routing-protocol.cc.

References ns3::Time::As(), m_ipv4, m_routingTable, ns3::Now(), and ns3::aodv::RoutingTable::Print().

+ Here is the call graph for this function:

◆ ProcessHello()

void ns3::aodv::RoutingProtocol::ProcessHello ( const RrepHeader rrepHeader,
Ipv4Address  receiverIfaceAddr 
)
private

◆ RecvAodv()

void ns3::aodv::RoutingProtocol::RecvAodv ( Ptr< Socket socket)
private

Receive and process control packet.

Parameters
socketinput socket

Definition at line 1206 of file aodv-routing-protocol.cc.

References ns3::aodv::AODVTYPE_RERR, ns3::aodv::AODVTYPE_RREP, ns3::aodv::AODVTYPE_RREP_ACK, ns3::aodv::AODVTYPE_RREQ, ns3::InetSocketAddress::ConvertFrom(), ns3::aodv::TypeHeader::Get(), ns3::InetSocketAddress::GetIpv4(), ns3::aodv::TypeHeader::IsValid(), m_socketAddresses, m_socketSubnetBroadcastAddresses, NS_ASSERT_MSG, NS_LOG_DEBUG, NS_LOG_FUNCTION, RecvError(), RecvReply(), RecvReplyAck(), RecvRequest(), and UpdateRouteToNeighbor().

Referenced by NotifyAddAddress(), NotifyInterfaceUp(), and NotifyRemoveAddress().

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

◆ RecvError()

void ns3::aodv::RoutingProtocol::RecvError ( Ptr< Packet p,
Ipv4Address  src 
)
private

Receive RERR.

Parameters
ppacket
srcsender address Receive from node with address src

Definition at line 1849 of file aodv-routing-protocol.cc.

References ns3::aodv::RerrHeader::AddUnDestination(), ns3::aodv::AODVTYPE_RERR, ns3::aodv::RerrHeader::Clear(), ns3::aodv::RerrHeader::GetDestCount(), ns3::aodv::RoutingTable::GetListOfDestinationWithNextHop(), ns3::aodv::RoutingTableEntry::GetPrecursors(), ns3::aodv::RoutingTable::InvalidateRoutesWithDst(), ns3::aodv::RoutingTable::LookupRoute(), m_routingTable, NS_LOG_FUNCTION, ns3::aodv::RerrHeader::RemoveUnDestination(), SendRerrMessage(), and ns3::SocketIpTtlTag::SetTtl().

Referenced by RecvAodv().

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

◆ RecvReply()

void ns3::aodv::RoutingProtocol::RecvReply ( Ptr< Packet p,
Ipv4Address  my,
Ipv4Address  src 
)
private

Receive RREP.

Parameters
ppacket
mydestination address
srcsender address

Definition at line 1644 of file aodv-routing-protocol.cc.

References ns3::aodv::RoutingTable::AddRoute(), AODV_PORT, ns3::aodv::AODVTYPE_RREP, FindSocketWithInterfaceAddress(), ns3::aodv::RrepHeader::GetAckRequired(), ns3::aodv::RrepHeader::GetDst(), ns3::aodv::RrepHeader::GetDstSeqno(), ns3::aodv::RoutingTableEntry::GetFlag(), ns3::aodv::RoutingTableEntry::GetHop(), ns3::aodv::RrepHeader::GetHopCount(), ns3::aodv::RoutingTableEntry::GetInterface(), ns3::aodv::RrepHeader::GetLifeTime(), ns3::aodv::RoutingTableEntry::GetLifeTime(), ns3::aodv::RoutingTableEntry::GetNextHop(), ns3::aodv::RrepHeader::GetOrigin(), ns3::aodv::RoutingTableEntry::GetRoute(), ns3::aodv::RoutingTableEntry::GetSeqNo(), ns3::SocketIpTtlTag::GetTtl(), ns3::aodv::RoutingTableEntry::GetValidSeqNo(), ns3::aodv::IN_SEARCH, ns3::aodv::RoutingTableEntry::InsertPrecursor(), IsMyOwnAddress(), ns3::aodv::RoutingTable::LookupRoute(), ns3::aodv::RoutingTable::LookupValidRoute(), m_activeRouteTimeout, m_addressReqTimer, m_ipv4, m_routingTable, NS_ASSERT, NS_LOG_DEBUG, NS_LOG_FUNCTION, NS_LOG_LOGIC, ProcessHello(), SendPacketFromQueue(), SendReplyAck(), ns3::aodv::RrepHeader::SetAckRequired(), ns3::aodv::RrepHeader::SetHopCount(), ns3::aodv::RoutingTableEntry::SetLifeTime(), ns3::SocketIpTtlTag::SetTtl(), ns3::aodv::RoutingTable::Update(), and ns3::aodv::VALID.

Referenced by RecvAodv().

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

◆ RecvReplyAck()

void ns3::aodv::RoutingProtocol::RecvReplyAck ( Ipv4Address  neighbor)
private

Receive RREP_ACK.

Parameters
neighborneighbor address

Definition at line 1793 of file aodv-routing-protocol.cc.

References ns3::Timer::Cancel(), ns3::aodv::RoutingTable::LookupRoute(), ns3::aodv::RoutingTableEntry::m_ackTimer, m_routingTable, NS_LOG_FUNCTION, ns3::aodv::RoutingTableEntry::SetFlag(), ns3::aodv::RoutingTable::Update(), and ns3::aodv::VALID.

Referenced by RecvAodv().

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

◆ RecvRequest()

void ns3::aodv::RoutingProtocol::RecvRequest ( Ptr< Packet p,
Ipv4Address  receiver,
Ipv4Address  src 
)
private

Receive RREQ.

Parameters
ppacket
receiverreceiver address
srcsender address

Definition at line 1324 of file aodv-routing-protocol.cc.

References ns3::aodv::RoutingTable::AddRoute(), ns3::aodv::AODVTYPE_RREQ, ns3::Ipv4InterfaceAddress::GetBroadcast(), ns3::aodv::RreqHeader::GetDestinationOnly(), ns3::aodv::RreqHeader::GetDst(), ns3::aodv::RreqHeader::GetDstSeqno(), ns3::aodv::RoutingTableEntry::GetFlag(), ns3::aodv::RreqHeader::GetGratuitousRrep(), ns3::aodv::RreqHeader::GetHopCount(), ns3::aodv::RreqHeader::GetId(), ns3::UniformRandomVariable::GetInteger(), ns3::aodv::RoutingTableEntry::GetLifeTime(), ns3::Ipv4InterfaceAddress::GetMask(), ns3::aodv::RoutingTableEntry::GetNextHop(), ns3::Ipv4Mask::GetOnes(), ns3::aodv::RreqHeader::GetOrigin(), ns3::aodv::RreqHeader::GetOriginSeqno(), ns3::aodv::RoutingTableEntry::GetSeqNo(), ns3::SocketIpTtlTag::GetTtl(), ns3::aodv::RreqHeader::GetUnknownSeqno(), ns3::aodv::RoutingTableEntry::GetValidSeqNo(), ns3::aodv::IdCache::IsDuplicate(), IsMyOwnAddress(), ns3::aodv::RoutingTableEntry::IsUnidirectional(), ns3::aodv::RoutingTable::LookupRoute(), m_activeRouteTimeout, m_allowedHelloLoss, m_helloInterval, m_ipv4, m_lastBcastTime, m_nb, m_netTraversalTime, m_nodeTraversalTime, m_routingTable, m_rreqIdCache, m_socketAddresses, m_uniformRandomVariable, ns3::MilliSeconds(), ns3::Simulator::Now(), NS_LOG_DEBUG, NS_LOG_FUNCTION, NS_LOG_LOGIC, ns3::Simulator::Schedule(), SendReply(), SendReplyByIntermediateNode(), SendTo(), ns3::aodv::RreqHeader::SetDstSeqno(), ns3::aodv::RoutingTableEntry::SetFlag(), ns3::aodv::RoutingTableEntry::SetHop(), ns3::aodv::RreqHeader::SetHopCount(), ns3::aodv::RoutingTableEntry::SetInterface(), ns3::aodv::RoutingTableEntry::SetLifeTime(), ns3::aodv::RoutingTableEntry::SetNextHop(), ns3::aodv::RoutingTableEntry::SetOutputDevice(), ns3::aodv::RoutingTableEntry::SetSeqNo(), ns3::SocketIpTtlTag::SetTtl(), ns3::aodv::RreqHeader::SetUnknownSeqno(), ns3::aodv::RoutingTableEntry::SetValidSeqNo(), ns3::aodv::Neighbors::Update(), ns3::aodv::RoutingTable::Update(), and ns3::aodv::VALID.

Referenced by RecvAodv().

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

◆ RerrRateLimitTimerExpire()

void ns3::aodv::RoutingProtocol::RerrRateLimitTimerExpire ( )
private

Reset RERR count and schedule RERR rate limit timer with delay 1 sec.

Definition at line 1978 of file aodv-routing-protocol.cc.

References m_rerrCount, m_rerrRateLimitTimer, NS_LOG_FUNCTION, ns3::Timer::Schedule(), and ns3::Seconds().

Referenced by Start().

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

◆ RouteInput()

bool ns3::aodv::RoutingProtocol::RouteInput ( Ptr< const Packet p,
const Ipv4Header header,
Ptr< const NetDevice idev,
const UnicastForwardCallback ucb,
const MulticastForwardCallback mcb,
const LocalDeliverCallback lcb,
const ErrorCallback ecb 
)
overridevirtual

Route an input packet (to be forwarded or locally delivered)

This lookup is used in the forwarding process. The packet is handed over to the Ipv4RoutingProtocol, and will get forwarded onward by one of the callbacks. The Linux equivalent is ip_route_input(). There are four valid outcomes, and a matching callbacks to handle each.

Parameters
preceived packet
headerinput parameter used to form a search key for a route
idevPointer to ingress network device
ucbCallback for the case in which the packet is to be forwarded as unicast
mcbCallback for the case in which the packet is to be forwarded as multicast
lcbCallback for the case in which the packet is to be locally delivered
ecbCallback to call if there is an error in forwarding
Returns
true if the Ipv4RoutingProtocol takes responsibility for forwarding or delivering the packet, false otherwise

Implements ns3::Ipv4RoutingProtocol.

Definition at line 494 of file aodv-routing-protocol.cc.

References AODV_PORT, DeferredRouteOutput(), ns3::Socket::ERROR_NOROUTETOHOST, Forwarding(), ns3::Ipv4InterfaceAddress::GetBroadcast(), ns3::Ipv4Header::GetDestination(), ns3::UdpHeader::GetDestinationPort(), ns3::Ipv4InterfaceAddress::GetLocal(), ns3::aodv::RoutingTableEntry::GetNextHop(), ns3::Ipv4Header::GetProtocol(), ns3::aodv::RoutingTableEntry::GetRoute(), ns3::Ipv4Header::GetSource(), ns3::Ipv4Header::GetTtl(), ns3::Ipv4Address::IsBroadcast(), ns3::aodv::DuplicatePacketDetection::IsDuplicate(), ns3::Ipv4Address::IsMulticast(), IsMyOwnAddress(), ns3::Callback< R, UArgs >::IsNull(), ns3::aodv::RoutingTable::LookupRoute(), ns3::aodv::RoutingTable::LookupValidRoute(), m_activeRouteTimeout, m_dpd, m_enableBroadcast, m_ipv4, m_lo, m_nb, m_routingTable, m_socketAddresses, NS_ASSERT, NS_LOG_DEBUG, NS_LOG_ERROR, NS_LOG_FUNCTION, NS_LOG_LOGIC, ns3::UdpL4Protocol::PROT_NUMBER, ns3::aodv::Neighbors::Update(), and UpdateRouteLifeTime().

+ Here is the call graph for this function:

◆ RouteOutput()

Ptr< Ipv4Route > ns3::aodv::RoutingProtocol::RouteOutput ( Ptr< Packet p,
const Ipv4Header header,
Ptr< NetDevice oif,
Socket::SocketErrno sockerr 
)
overridevirtual

Query routing cache for an existing route, for an outbound packet.

This lookup is used by transport protocols. It does not cause any packet to be forwarded, and is synchronous. Can be used for multicast or unicast. The Linux equivalent is ip_route_output()

The header input parameter may have an uninitialized value for the source address, but the destination address should always be properly set by the caller.

Parameters
ppacket to be routed. Note that this method may modify the packet. Callers may also pass in a null pointer.
headerinput parameter (used to form key to search for the route)
oifOutput interface Netdevice. May be zero, or may be bound via socket options to a particular output interface.
sockerrOutput parameter; socket errno
Returns
a code that indicates what happened in the lookup

Implements ns3::Ipv4RoutingProtocol.

Definition at line 416 of file aodv-routing-protocol.cc.

References ns3::Socket::ERROR_NOROUTETOHOST, ns3::Socket::ERROR_NOTERROR, ns3::Ipv4Header::GetDestination(), ns3::aodv::RoutingTableEntry::GetRoute(), ns3::aodv::RoutingTable::LookupValidRoute(), LoopbackRoute(), m_activeRouteTimeout, m_ipv4, m_routingTable, m_socketAddresses, NS_ASSERT, NS_LOG_DEBUG, NS_LOG_FUNCTION, NS_LOG_LOGIC, and UpdateRouteLifeTime().

+ Here is the call graph for this function:

◆ RouteRequestTimerExpire()

void ns3::aodv::RoutingProtocol::RouteRequestTimerExpire ( Ipv4Address  dst)
private

Handle route discovery process.

Parameters
dstthe destination IP address

Definition at line 1907 of file aodv-routing-protocol.cc.

References ns3::aodv::RoutingTable::DeleteRoute(), ns3::aodv::RequestQueue::DropPacketWithDst(), ns3::aodv::RoutingTableEntry::GetFlag(), ns3::aodv::RoutingTableEntry::GetHop(), ns3::aodv::RoutingTableEntry::GetRoute(), ns3::aodv::RoutingTableEntry::GetRreqCnt(), ns3::aodv::IN_SEARCH, ns3::aodv::RoutingTable::LookupValidRoute(), m_addressReqTimer, m_netDiameter, m_queue, m_routingTable, m_rreqRetries, NS_LOG_DEBUG, NS_LOG_LOGIC, SendPacketFromQueue(), and SendRequest().

Referenced by ScheduleRreqRetry().

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

◆ RreqRateLimitTimerExpire()

void ns3::aodv::RoutingProtocol::RreqRateLimitTimerExpire ( )
private

Reset RREQ count and schedule RREQ rate limit timer with delay 1 sec.

Definition at line 1970 of file aodv-routing-protocol.cc.

References m_rreqCount, m_rreqRateLimitTimer, NS_LOG_FUNCTION, ns3::Timer::Schedule(), and ns3::Seconds().

Referenced by Start().

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

◆ ScheduleRreqRetry()

void ns3::aodv::RoutingProtocol::ScheduleRreqRetry ( Ipv4Address  dst)
private

Repeated attempts by a source node at route discovery for a single destination use the expanding ring search technique.

Parameters
dstthe destination IP address

Definition at line 1176 of file aodv-routing-protocol.cc.

References ns3::Time::As(), ns3::Timer::CANCEL_ON_DESTROY, ns3::aodv::RoutingTableEntry::GetHop(), ns3::aodv::RoutingTableEntry::GetRreqCnt(), ns3::aodv::RoutingTable::LookupRoute(), m_addressReqTimer, m_netDiameter, m_netTraversalTime, m_nodeTraversalTime, m_routingTable, m_timeoutBuffer, NS_ABORT_MSG_UNLESS, NS_LOG_FUNCTION, NS_LOG_LOGIC, RouteRequestTimerExpire(), and ns3::Time::S.

Referenced by SendRequest().

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

◆ SendHello()

void ns3::aodv::RoutingProtocol::SendHello ( )
private

Send hello.

Definition at line 1993 of file aodv-routing-protocol.cc.

References ns3::aodv::AODVTYPE_RREP, ns3::Ipv4InterfaceAddress::GetBroadcast(), ns3::UniformRandomVariable::GetInteger(), ns3::Ipv4InterfaceAddress::GetLocal(), ns3::Ipv4InterfaceAddress::GetMask(), ns3::Ipv4Mask::GetOnes(), m_allowedHelloLoss, m_helloInterval, m_seqNo, m_socketAddresses, m_uniformRandomVariable, ns3::MilliSeconds(), NS_LOG_FUNCTION, ns3::Simulator::Schedule(), SendTo(), and ns3::SocketIpTtlTag::SetTtl().

Referenced by HelloTimerExpire().

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

◆ SendPacketFromQueue()

void ns3::aodv::RoutingProtocol::SendPacketFromQueue ( Ipv4Address  dst,
Ptr< Ipv4Route route 
)
private

Forward packet from route request queue.

Parameters
dstdestination address
routeroute to use

Definition at line 2035 of file aodv-routing-protocol.cc.

References ns3::aodv::RequestQueue::Dequeue(), ns3::aodv::DeferredRouteOutputTag::GetInterface(), ns3::aodv::QueueEntry::GetIpv4Header(), ns3::aodv::QueueEntry::GetPacket(), ns3::Ipv4Header::GetTtl(), ns3::aodv::QueueEntry::GetUnicastForwardCallback(), m_ipv4, m_queue, NS_LOG_DEBUG, NS_LOG_FUNCTION, ns3::Ipv4Header::SetSource(), and ns3::Ipv4Header::SetTtl().

Referenced by RecvReply(), and RouteRequestTimerExpire().

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

◆ SendReply()

void ns3::aodv::RoutingProtocol::SendReply ( const RreqHeader rreqHeader,
const RoutingTableEntry toOrigin 
)
private

Send RREP.

Parameters
rreqHeaderroute request header
toOriginrouting table entry to originator

Definition at line 1531 of file aodv-routing-protocol.cc.

References AODV_PORT, ns3::aodv::AODVTYPE_RREP, FindSocketWithInterfaceAddress(), ns3::aodv::RoutingTableEntry::GetDestination(), ns3::aodv::RreqHeader::GetDst(), ns3::aodv::RreqHeader::GetDstSeqno(), ns3::aodv::RoutingTableEntry::GetHop(), ns3::aodv::RoutingTableEntry::GetInterface(), ns3::aodv::RoutingTableEntry::GetNextHop(), ns3::aodv::RreqHeader::GetUnknownSeqno(), m_myRouteTimeout, m_seqNo, NS_ASSERT, NS_LOG_FUNCTION, and ns3::SocketIpTtlTag::SetTtl().

Referenced by RecvRequest().

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

◆ SendReplyAck()

void ns3::aodv::RoutingProtocol::SendReplyAck ( Ipv4Address  neighbor)
private

Send RREP_ACK.

Parameters
neighborneighbor address

Definition at line 1625 of file aodv-routing-protocol.cc.

References AODV_PORT, ns3::aodv::AODVTYPE_RREP_ACK, FindSocketWithInterfaceAddress(), ns3::aodv::RoutingTableEntry::GetInterface(), ns3::aodv::RoutingTable::LookupRoute(), m_routingTable, NS_ASSERT, NS_LOG_FUNCTION, and ns3::SocketIpTtlTag::SetTtl().

Referenced by RecvReply().

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

◆ SendReplyByIntermediateNode()

void ns3::aodv::RoutingProtocol::SendReplyByIntermediateNode ( RoutingTableEntry toDst,
RoutingTableEntry toOrigin,
bool  gratRep 
)
private

Send RREP by intermediate node.

Parameters
toDstrouting table entry to destination
toOriginrouting table entry to originator
gratRepindicates whether a gratuitous RREP should be unicast to destination

Definition at line 1562 of file aodv-routing-protocol.cc.

References AckTimerExpire(), AODV_PORT, ns3::aodv::AODVTYPE_RREP, FindSocketWithInterfaceAddress(), ns3::aodv::RoutingTableEntry::GetDestination(), ns3::aodv::RoutingTableEntry::GetHop(), ns3::aodv::RoutingTableEntry::GetInterface(), ns3::aodv::RoutingTableEntry::GetLifeTime(), ns3::aodv::RoutingTableEntry::GetNextHop(), ns3::aodv::RoutingTableEntry::GetSeqNo(), ns3::aodv::RoutingTableEntry::InsertPrecursor(), ns3::aodv::RoutingTable::LookupRoute(), ns3::aodv::RoutingTableEntry::m_ackTimer, m_blackListTimeout, m_nextHopWait, m_routingTable, NS_ASSERT, NS_LOG_FUNCTION, NS_LOG_LOGIC, ns3::aodv::RrepHeader::SetAckRequired(), ns3::Timer::SetArguments(), ns3::Timer::SetDelay(), ns3::Timer::SetFunction(), ns3::SocketIpTtlTag::SetTtl(), and ns3::aodv::RoutingTable::Update().

Referenced by RecvRequest().

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

◆ SendRequest()

void ns3::aodv::RoutingProtocol::SendRequest ( Ipv4Address  dst)
private

Send RREQ.

Parameters
dstdestination address

Definition at line 1042 of file aodv-routing-protocol.cc.

References ns3::aodv::RoutingTable::AddRoute(), ns3::aodv::AODVTYPE_RREQ, ns3::Ipv4InterfaceAddress::GetBroadcast(), ns3::Timer::GetDelayLeft(), ns3::aodv::RoutingTableEntry::GetFlag(), ns3::aodv::RoutingTableEntry::GetHop(), ns3::aodv::RreqHeader::GetId(), ns3::UniformRandomVariable::GetInteger(), ns3::Ipv4InterfaceAddress::GetLocal(), ns3::Ipv4InterfaceAddress::GetMask(), ns3::Ipv4Mask::GetOnes(), ns3::aodv::RoutingTableEntry::GetSeqNo(), ns3::aodv::RoutingTableEntry::GetValidSeqNo(), ns3::aodv::IN_SEARCH, ns3::aodv::RoutingTableEntry::IncrementRreqCnt(), ns3::aodv::IdCache::IsDuplicate(), ns3::aodv::RoutingTable::LookupRoute(), m_destinationOnly, m_gratuitousReply, m_lastBcastTime, m_netDiameter, m_pathDiscoveryTime, m_requestId, m_routingTable, m_rreqCount, m_rreqIdCache, m_rreqRateLimit, m_rreqRateLimitTimer, m_seqNo, m_socketAddresses, m_ttlIncrement, m_ttlStart, m_ttlThreshold, m_uniformRandomVariable, ns3::MicroSeconds(), ns3::MilliSeconds(), ns3::Simulator::Now(), NS_LOG_DEBUG, NS_LOG_FUNCTION, ns3::Simulator::Schedule(), ScheduleRreqRetry(), SendRequest(), SendTo(), ns3::aodv::RreqHeader::SetDestinationOnly(), ns3::aodv::RreqHeader::SetDst(), ns3::aodv::RreqHeader::SetDstSeqno(), ns3::aodv::RoutingTableEntry::SetFlag(), ns3::aodv::RreqHeader::SetGratuitousRrep(), ns3::aodv::RoutingTableEntry::SetHop(), ns3::aodv::RreqHeader::SetId(), ns3::aodv::RoutingTableEntry::SetLifeTime(), ns3::aodv::RreqHeader::SetOrigin(), ns3::aodv::RreqHeader::SetOriginSeqno(), ns3::SocketIpTtlTag::SetTtl(), ns3::aodv::RreqHeader::SetUnknownSeqno(), and ns3::aodv::RoutingTable::Update().

Referenced by DeferredRouteOutput(), RouteRequestTimerExpire(), and SendRequest().

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

◆ SendRerrMessage()

void ns3::aodv::RoutingProtocol::SendRerrMessage ( Ptr< Packet packet,
std::vector< Ipv4Address precursors 
)
private

Forward RERR.

Parameters
packetpacket
precursorslist of addresses of the visited nodes

Definition at line 2169 of file aodv-routing-protocol.cc.

References ns3::Time::As(), FindSocketWithInterfaceAddress(), ns3::Ipv4Address::GetBroadcast(), ns3::Timer::GetDelayLeft(), ns3::aodv::RoutingTableEntry::GetDestination(), ns3::UniformRandomVariable::GetInteger(), ns3::aodv::RoutingTableEntry::GetInterface(), ns3::Ipv4InterfaceAddress::GetLocal(), ns3::Ipv4Mask::GetOnes(), ns3::Timer::IsRunning(), ns3::aodv::RoutingTable::LookupValidRoute(), m_rerrCount, m_rerrRateLimit, m_rerrRateLimitTimer, m_routingTable, m_uniformRandomVariable, ns3::MilliSeconds(), ns3::Simulator::Now(), NS_ASSERT, NS_LOG_FUNCTION, NS_LOG_LOGIC, ns3::Time::S, ns3::Simulator::Schedule(), and SendTo().

Referenced by RecvError(), and SendRerrWhenBreaksLinkToNextHop().

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

◆ SendRerrWhenBreaksLinkToNextHop()

void ns3::aodv::RoutingProtocol::SendRerrWhenBreaksLinkToNextHop ( Ipv4Address  nextHop)
private

Initiate RERR.

Parameters
nextHopnext hop address

Definition at line 2059 of file aodv-routing-protocol.cc.

References ns3::aodv::RerrHeader::AddUnDestination(), ns3::aodv::AODVTYPE_RERR, ns3::aodv::RerrHeader::Clear(), ns3::aodv::RerrHeader::GetDestCount(), ns3::aodv::RoutingTable::GetListOfDestinationWithNextHop(), ns3::aodv::RoutingTableEntry::GetPrecursors(), ns3::aodv::RoutingTableEntry::GetSeqNo(), ns3::aodv::RoutingTable::InvalidateRoutesWithDst(), ns3::aodv::RoutingTable::LookupRoute(), m_routingTable, NS_LOG_FUNCTION, NS_LOG_LOGIC, SendRerrMessage(), and ns3::SocketIpTtlTag::SetTtl().

Referenced by RoutingProtocol().

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

◆ SendRerrWhenNoRouteToForward()

void ns3::aodv::RoutingProtocol::SendRerrWhenNoRouteToForward ( Ipv4Address  dst,
uint32_t  dstSeqNo,
Ipv4Address  origin 
)
private

Send RERR message when no route to forward input packet.

Unicast if there is reverse route to originating node, broadcast otherwise.

Parameters
dstdestination node IP address
dstSeqNodestination node sequence number
originoriginating node IP address

Definition at line 2113 of file aodv-routing-protocol.cc.

References ns3::aodv::RerrHeader::AddUnDestination(), AODV_PORT, ns3::aodv::AODVTYPE_RERR, ns3::Time::As(), FindSocketWithInterfaceAddress(), ns3::Ipv4InterfaceAddress::GetBroadcast(), ns3::Timer::GetDelayLeft(), ns3::aodv::RoutingTableEntry::GetInterface(), ns3::Ipv4InterfaceAddress::GetLocal(), ns3::Ipv4InterfaceAddress::GetMask(), ns3::aodv::RoutingTableEntry::GetNextHop(), ns3::Ipv4Mask::GetOnes(), ns3::Timer::IsRunning(), ns3::aodv::RoutingTable::LookupValidRoute(), m_rerrCount, m_rerrRateLimit, m_rerrRateLimitTimer, m_routingTable, m_socketAddresses, ns3::Simulator::Now(), NS_ASSERT, NS_LOG_FUNCTION, NS_LOG_LOGIC, ns3::Time::S, and ns3::SocketIpTtlTag::SetTtl().

Referenced by Forwarding().

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

◆ SendTo()

void ns3::aodv::RoutingProtocol::SendTo ( Ptr< Socket socket,
Ptr< Packet packet,
Ipv4Address  destination 
)
private

Send packet to destination socket.

Parameters
socketdestination node socket
packetpacket to send
destinationdestination node IP address

Definition at line 1170 of file aodv-routing-protocol.cc.

References AODV_PORT.

Referenced by RecvRequest(), SendHello(), SendRequest(), and SendRerrMessage().

+ Here is the caller graph for this function:

◆ SetBroadcastEnable()

void ns3::aodv::RoutingProtocol::SetBroadcastEnable ( bool  f)
inline

Set broadcast enable flag.

Parameters
fenable broadcast flag

Definition at line 182 of file aodv-routing-protocol.h.

References m_enableBroadcast.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

◆ SetDestinationOnlyFlag()

void ns3::aodv::RoutingProtocol::SetDestinationOnlyFlag ( bool  f)
inline

Set destination only flag.

Parameters
fthe destination only flag

Definition at line 137 of file aodv-routing-protocol.h.

References m_destinationOnly.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

◆ SetGratuitousReplyFlag()

void ns3::aodv::RoutingProtocol::SetGratuitousReplyFlag ( bool  f)
inline

Set gratuitous reply flag.

Parameters
fthe gratuitous reply flag

Definition at line 155 of file aodv-routing-protocol.h.

References m_gratuitousReply.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

◆ SetHelloEnable()

void ns3::aodv::RoutingProtocol::SetHelloEnable ( bool  f)
inline

Set hello enable.

Parameters
fthe hello enable flag

Definition at line 164 of file aodv-routing-protocol.h.

References m_enableHello.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

◆ SetIpv4()

void ns3::aodv::RoutingProtocol::SetIpv4 ( Ptr< Ipv4 ipv4)
overridevirtual
Parameters
ipv4the ipv4 object this routing protocol is being associated with

Typically, invoked directly or indirectly from ns3::Ipv4::SetRoutingProtocol

Implements ns3::Ipv4RoutingProtocol.

Definition at line 702 of file aodv-routing-protocol.cc.

References ns3::aodv::RoutingTable::AddRoute(), ns3::Ipv4Address::GetLoopback(), ns3::Simulator::GetMaximumSimulationTime(), m_ipv4, m_lo, m_routingTable, NS_ASSERT, ns3::Simulator::ScheduleNow(), and Start().

+ Here is the call graph for this function:

◆ SetMaxQueueLen()

void ns3::aodv::RoutingProtocol::SetMaxQueueLen ( uint32_t  len)

Set the maximum queue length.

Parameters
lenthe maximum queue length

Definition at line 344 of file aodv-routing-protocol.cc.

References m_maxQueueLen, m_queue, and ns3::aodv::RequestQueue::SetMaxQueueLen().

Referenced by GetTypeId().

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

◆ SetMaxQueueTime()

void ns3::aodv::RoutingProtocol::SetMaxQueueTime ( Time  t)

Set the maximum queue time.

Parameters
tthe maximum queue time

Definition at line 351 of file aodv-routing-protocol.cc.

References m_maxQueueTime, m_queue, and ns3::aodv::RequestQueue::SetQueueTimeout().

Referenced by GetTypeId().

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

◆ Start()

void ns3::aodv::RoutingProtocol::Start ( )
private

Start protocol operation.

Definition at line 401 of file aodv-routing-protocol.cc.

References m_enableHello, m_nb, m_rerrRateLimitTimer, m_rreqRateLimitTimer, NS_LOG_FUNCTION, RerrRateLimitTimerExpire(), RreqRateLimitTimerExpire(), ns3::Timer::Schedule(), ns3::aodv::Neighbors::ScheduleTimer(), ns3::Seconds(), and ns3::Timer::SetFunction().

Referenced by SetIpv4().

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

◆ UpdateRouteLifeTime()

bool ns3::aodv::RoutingProtocol::UpdateRouteLifeTime ( Ipv4Address  addr,
Time  lt 
)
private

Set lifetime field in routing table entry to the maximum of existing lifetime and lt, if the entry exists.

Parameters
addrdestination address
ltproposed time for lifetime field in routing table entry for destination with address addr.
Returns
true if route to destination address addr exist

Definition at line 1262 of file aodv-routing-protocol.cc.

References ns3::aodv::RoutingTableEntry::GetFlag(), ns3::aodv::RoutingTableEntry::GetLifeTime(), ns3::aodv::RoutingTable::LookupRoute(), m_routingTable, NS_LOG_DEBUG, NS_LOG_FUNCTION, ns3::aodv::RoutingTableEntry::SetLifeTime(), ns3::aodv::RoutingTableEntry::SetRreqCnt(), ns3::aodv::RoutingTable::Update(), and ns3::aodv::VALID.

Referenced by Forwarding(), RouteInput(), and RouteOutput().

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

◆ UpdateRouteToNeighbor()

void ns3::aodv::RoutingProtocol::UpdateRouteToNeighbor ( Ipv4Address  sender,
Ipv4Address  receiver 
)
private

Update neighbor record.

Parameters
receiveris supposed to be my interface
senderis supposed to be IP address of my neighbor.

Definition at line 1281 of file aodv-routing-protocol.cc.

References ns3::aodv::RoutingTable::AddRoute(), ns3::aodv::RoutingTableEntry::GetHop(), ns3::aodv::RoutingTableEntry::GetLifeTime(), ns3::aodv::RoutingTableEntry::GetOutputDevice(), ns3::aodv::RoutingTableEntry::GetValidSeqNo(), ns3::aodv::RoutingTable::LookupRoute(), m_activeRouteTimeout, m_ipv4, m_routingTable, NS_LOG_FUNCTION, ns3::aodv::RoutingTableEntry::SetLifeTime(), and ns3::aodv::RoutingTable::Update().

Referenced by RecvAodv().

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

Member Data Documentation

◆ AODV_PORT

const uint32_t ns3::aodv::RoutingProtocol::AODV_PORT = 654
static

◆ m_activeRouteTimeout

Time ns3::aodv::RoutingProtocol::m_activeRouteTimeout
private

Period of time during which the route is considered to be valid.

Definition at line 229 of file aodv-routing-protocol.h.

Referenced by Forwarding(), GetTypeId(), RecvReply(), RecvRequest(), RouteInput(), RouteOutput(), and UpdateRouteToNeighbor().

◆ m_addressReqTimer

std::map<Ipv4Address, Timer> ns3::aodv::RoutingProtocol::m_addressReqTimer
private

Map IP address + RREQ timer.

Definition at line 488 of file aodv-routing-protocol.h.

Referenced by RecvReply(), RouteRequestTimerExpire(), and ScheduleRreqRetry().

◆ m_allowedHelloLoss

uint32_t ns3::aodv::RoutingProtocol::m_allowedHelloLoss
private

Number of hello messages which may be loss for valid link.

Definition at line 245 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), ProcessHello(), RecvRequest(), and SendHello().

◆ m_blackListTimeout

Time ns3::aodv::RoutingProtocol::m_blackListTimeout
private

Time for which the node is put into the blacklist.

Definition at line 253 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), and SendReplyByIntermediateNode().

◆ m_deletePeriod

Time ns3::aodv::RoutingProtocol::m_deletePeriod
private

DeletePeriod is intended to provide an upper bound on the time for which an upstream node A can have a neighbor B as an active next hop for destination D, while B has invalidated the route to D.

Definition at line 251 of file aodv-routing-protocol.h.

Referenced by GetTypeId().

◆ m_destinationOnly

bool ns3::aodv::RoutingProtocol::m_destinationOnly
private

Indicates only the destination may respond to this RREQ.

Definition at line 258 of file aodv-routing-protocol.h.

Referenced by GetDestinationOnlyFlag(), SendRequest(), and SetDestinationOnlyFlag().

◆ m_dpd

DuplicatePacketDetection ns3::aodv::RoutingProtocol::m_dpd
private

Handle duplicated broadcast/multicast packets.

Definition at line 286 of file aodv-routing-protocol.h.

Referenced by RouteInput().

◆ m_enableBroadcast

bool ns3::aodv::RoutingProtocol::m_enableBroadcast
private

Indicates whether a a broadcast data packets forwarding enable.

Definition at line 262 of file aodv-routing-protocol.h.

Referenced by GetBroadcastEnable(), RouteInput(), and SetBroadcastEnable().

◆ m_enableHello

bool ns3::aodv::RoutingProtocol::m_enableHello
private

Indicates whether a hello messages enable.

Definition at line 261 of file aodv-routing-protocol.h.

Referenced by DoInitialize(), GetHelloEnable(), ProcessHello(), SetHelloEnable(), and Start().

◆ m_gratuitousReply

bool ns3::aodv::RoutingProtocol::m_gratuitousReply
private

Indicates whether a gratuitous RREP should be unicast to the node originated route discovery.

Definition at line 259 of file aodv-routing-protocol.h.

Referenced by GetGratuitousReplyFlag(), SendRequest(), and SetGratuitousReplyFlag().

◆ m_helloInterval

Time ns3::aodv::RoutingProtocol::m_helloInterval
private

Every HelloInterval the node checks whether it has sent a broadcast within the last HelloInterval.

If it has not, it MAY broadcast a Hello message

Definition at line 244 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), HelloTimerExpire(), ProcessHello(), RecvRequest(), and SendHello().

◆ m_htimer

Timer ns3::aodv::RoutingProtocol::m_htimer
private

Hello timer.

Definition at line 476 of file aodv-routing-protocol.h.

Referenced by DoInitialize(), HelloTimerExpire(), NotifyInterfaceDown(), and NotifyRemoveAddress().

◆ m_ipv4

◆ m_lastBcastTime

Time ns3::aodv::RoutingProtocol::m_lastBcastTime
private

Keep track of the last bcast time.

Definition at line 505 of file aodv-routing-protocol.h.

Referenced by HelloTimerExpire(), RecvRequest(), and SendRequest().

◆ m_lo

Ptr<NetDevice> ns3::aodv::RoutingProtocol::m_lo
private

Loopback device used to defer RREQ until packet will be fully formed.

Definition at line 272 of file aodv-routing-protocol.h.

Referenced by LoopbackRoute(), RouteInput(), and SetIpv4().

◆ m_maxQueueLen

uint32_t ns3::aodv::RoutingProtocol::m_maxQueueLen
private

The maximum number of packets that we allow a routing protocol to buffer.

Definition at line 254 of file aodv-routing-protocol.h.

Referenced by GetMaxQueueLen(), and SetMaxQueueLen().

◆ m_maxQueueTime

Time ns3::aodv::RoutingProtocol::m_maxQueueTime
private

The maximum period of time that a routing protocol is allowed to buffer a packet for.

Definition at line 256 of file aodv-routing-protocol.h.

Referenced by GetMaxQueueTime(), and SetMaxQueueTime().

◆ m_myRouteTimeout

Time ns3::aodv::RoutingProtocol::m_myRouteTimeout
private

Value of lifetime field in RREP generating by this node.

Definition at line 239 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), and SendReply().

◆ m_nb

Neighbors ns3::aodv::RoutingProtocol::m_nb
private

◆ m_netDiameter

uint32_t ns3::aodv::RoutingProtocol::m_netDiameter
private

Net diameter measures the maximum possible number of hops between two nodes in the network.

Definition at line 230 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), RouteRequestTimerExpire(), ScheduleRreqRetry(), and SendRequest().

◆ m_netTraversalTime

Time ns3::aodv::RoutingProtocol::m_netTraversalTime
private

Estimate of the average net traversal time.

Definition at line 237 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), RecvRequest(), and ScheduleRreqRetry().

◆ m_nextHopWait

Time ns3::aodv::RoutingProtocol::m_nextHopWait
private

Period of our waiting for the neighbour's RREP_ACK.

Definition at line 252 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), and SendReplyByIntermediateNode().

◆ m_nodeTraversalTime

Time ns3::aodv::RoutingProtocol::m_nodeTraversalTime
private

NodeTraversalTime is a conservative estimate of the average one hop traversal time for packets and should include queuing delays, interrupt processing times and transfer times.

Definition at line 236 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), RecvRequest(), and ScheduleRreqRetry().

◆ m_pathDiscoveryTime

Time ns3::aodv::RoutingProtocol::m_pathDiscoveryTime
private

Estimate of maximum time needed to find route in network.

Definition at line 238 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), and SendRequest().

◆ m_queue

RequestQueue ns3::aodv::RoutingProtocol::m_queue
private

A "drop-front" queue used by the routing layer to buffer packets to which it does not have a route.

Definition at line 278 of file aodv-routing-protocol.h.

Referenced by DeferredRouteOutput(), RouteRequestTimerExpire(), SendPacketFromQueue(), SetMaxQueueLen(), and SetMaxQueueTime().

◆ m_requestId

uint32_t ns3::aodv::RoutingProtocol::m_requestId
private

Broadcast ID.

Definition at line 280 of file aodv-routing-protocol.h.

Referenced by SendRequest().

◆ m_rerrCount

uint16_t ns3::aodv::RoutingProtocol::m_rerrCount
private

Number of RERRs used for RERR rate control.

Definition at line 292 of file aodv-routing-protocol.h.

Referenced by RerrRateLimitTimerExpire(), SendRerrMessage(), and SendRerrWhenNoRouteToForward().

◆ m_rerrRateLimit

uint16_t ns3::aodv::RoutingProtocol::m_rerrRateLimit
private

Maximum number of REER per second.

Definition at line 228 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), SendRerrMessage(), and SendRerrWhenNoRouteToForward().

◆ m_rerrRateLimitTimer

Timer ns3::aodv::RoutingProtocol::m_rerrRateLimitTimer
private

RERR rate limit timer.

Definition at line 484 of file aodv-routing-protocol.h.

Referenced by RerrRateLimitTimerExpire(), SendRerrMessage(), SendRerrWhenNoRouteToForward(), and Start().

◆ m_routingTable

◆ m_rreqCount

uint16_t ns3::aodv::RoutingProtocol::m_rreqCount
private

Number of RREQs used for RREQ rate control.

Definition at line 290 of file aodv-routing-protocol.h.

Referenced by RreqRateLimitTimerExpire(), and SendRequest().

◆ m_rreqIdCache

IdCache ns3::aodv::RoutingProtocol::m_rreqIdCache
private

Handle duplicated RREQ.

Definition at line 284 of file aodv-routing-protocol.h.

Referenced by RecvRequest(), and SendRequest().

◆ m_rreqRateLimit

uint16_t ns3::aodv::RoutingProtocol::m_rreqRateLimit
private

Maximum number of RREQ per second.

Definition at line 227 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), and SendRequest().

◆ m_rreqRateLimitTimer

Timer ns3::aodv::RoutingProtocol::m_rreqRateLimitTimer
private

RREQ rate limit timer.

Definition at line 480 of file aodv-routing-protocol.h.

Referenced by RreqRateLimitTimerExpire(), SendRequest(), and Start().

◆ m_rreqRetries

uint32_t ns3::aodv::RoutingProtocol::m_rreqRetries
private

Maximum number of retransmissions of RREQ with TTL = NetDiameter to discover a route.

Definition at line 219 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), and RouteRequestTimerExpire().

◆ m_seqNo

uint32_t ns3::aodv::RoutingProtocol::m_seqNo
private

Request sequence number.

Definition at line 282 of file aodv-routing-protocol.h.

Referenced by SendHello(), SendReply(), and SendRequest().

◆ m_socketAddresses

std::map<Ptr<Socket>, Ipv4InterfaceAddress> ns3::aodv::RoutingProtocol::m_socketAddresses
private

◆ m_socketSubnetBroadcastAddresses

std::map<Ptr<Socket>, Ipv4InterfaceAddress> ns3::aodv::RoutingProtocol::m_socketSubnetBroadcastAddresses
private

Raw subnet directed broadcast socket per each IP interface, map socket -> iface address (IP.

  • mask)

Definition at line 270 of file aodv-routing-protocol.h.

Referenced by DoDispose(), FindSubnetBroadcastSocketWithInterfaceAddress(), NotifyAddAddress(), NotifyInterfaceDown(), NotifyInterfaceUp(), NotifyRemoveAddress(), and RecvAodv().

◆ m_timeoutBuffer

uint16_t ns3::aodv::RoutingProtocol::m_timeoutBuffer
private

Provide a buffer for the timeout.

Definition at line 226 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), and ScheduleRreqRetry().

◆ m_ttlIncrement

uint16_t ns3::aodv::RoutingProtocol::m_ttlIncrement
private

TTL increment for each attempt using the expanding ring search for RREQ dissemination.

Definition at line 222 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), and SendRequest().

◆ m_ttlStart

uint16_t ns3::aodv::RoutingProtocol::m_ttlStart
private

Initial TTL value for RREQ.

Definition at line 221 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), and SendRequest().

◆ m_ttlThreshold

uint16_t ns3::aodv::RoutingProtocol::m_ttlThreshold
private

Maximum TTL value for expanding ring search, TTL = NetDiameter is used beyond this value.

Definition at line 224 of file aodv-routing-protocol.h.

Referenced by GetTypeId(), and SendRequest().

◆ m_uniformRandomVariable

Ptr<UniformRandomVariable> ns3::aodv::RoutingProtocol::m_uniformRandomVariable
private

Provides uniform random variables.

Definition at line 503 of file aodv-routing-protocol.h.

Referenced by AssignStreams(), DoInitialize(), GetTypeId(), RecvRequest(), SendHello(), SendRequest(), and SendRerrMessage().


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