28#include "ns3/assert.h"
33#include "ns3/random-variable-stream.h"
34#include "ns3/simulator.h"
35#include "ns3/uinteger.h"
39#define RIPNG_ALL_NODE "ff02::9"
51 m_splitHorizonStrategy(
RipNg::POISON_REVERSE),
54 m_rng = CreateObject<UniformRandomVariable>();
67 .SetGroupName(
"Internet")
68 .AddConstructor<
RipNg>()
69 .AddAttribute(
"UnsolicitedRoutingUpdate",
70 "The time between two Unsolicited Routing Updates.",
74 .AddAttribute(
"StartupDelay",
75 "Maximum random delay for protocol startup (send route requests).",
79 .AddAttribute(
"TimeoutDelay",
80 "The delay to invalidate a route.",
84 .AddAttribute(
"GarbageCollectionDelay",
85 "The delay to delete an expired route.",
89 .AddAttribute(
"MinTriggeredCooldown",
90 "Min cooldown delay after a Triggered Update.",
94 .AddAttribute(
"MaxTriggeredCooldown",
95 "Max cooldown delay after a Triggered Update.",
99 .AddAttribute(
"SplitHorizon",
100 "Split Horizon strategy.",
109 .AddAttribute(
"LinkDownValue",
110 "Value for link down in count to infinity.",
113 MakeUintegerChecker<uint8_t>());
131 bool addedGlobal =
false;
141 bool activeInterface =
false;
144 activeInterface =
true;
145 m_ipv6->SetForwarding(i,
true);
153 NS_LOG_LOGIC(
"RIPng: adding socket to " << address.GetAddress());
158 socket->BindToNetDevice(
m_ipv6->GetNetDevice(i));
159 int ret = socket->Bind(local);
162 socket->SetIpv6RecvHopLimit(
true);
163 socket->SetRecvPktInfo(
true);
221 rtentry =
Lookup(destination,
true, oif);
258 NS_LOG_LOGIC(
"Dropping packet not for me and with src or dst LinkLocal");
267 if (!
m_ipv6->IsForwarding(iif))
282 NS_LOG_LOGIC(
"Found unicast destination - calling unicast callback");
283 ucb(idev, rtentry, p, header);
288 NS_LOG_LOGIC(
"Did not find unicast destination - returning false");
302 Ipv6Address networkAddress = address.GetAddress().CombinePrefix(networkMask);
315 bool sendSocketFound =
false;
318 if (iter->second == i)
320 sendSocketFound =
true;
325 bool activeInterface =
false;
328 activeInterface =
true;
329 m_ipv6->SetForwarding(i,
true);
339 NS_LOG_LOGIC(
"RIPng: adding sending socket to " << address.GetAddress());
344 socket->BindToNetDevice(
m_ipv6->GetNetDevice(i));
347 socket->SetIpv6RecvHopLimit(
true);
348 socket->SetRecvPktInfo(
true);
379 if (it->first->GetInterface() == interface)
387 NS_LOG_INFO(
"Checking socket for interface " << interface);
388 if (iter->second == interface)
390 NS_LOG_INFO(
"Removed socket for interface " << interface);
391 iter->first->Close();
408 if (!
m_ipv6->IsUp(interface))
418 Ipv6Address networkAddress = address.GetAddress().CombinePrefix(address.GetPrefix());
434 if (!
m_ipv6->IsUp(interface))
444 Ipv6Address networkAddress = address.GetAddress().CombinePrefix(address.GetPrefix());
451 if (it->first->GetInterface() == interface && it->first->IsNetwork() &&
452 it->first->GetDestNetwork() == networkAddress &&
453 it->first->GetDestNetworkPrefix() == networkMask)
472 NS_LOG_INFO(
this << dst << mask << nextHop << interface << prefixToUse);
496 for (i = 0; i <
m_ipv6->GetNInterfaces(); i++)
514 std::ostream* os = stream->GetStream();
515 *os << std::resetiosflags(std::ios::adjustfield) << std::setiosflags(std::ios::left);
517 *os <<
"Node: " <<
m_ipv6->GetObject<
Node>()->GetId() <<
", Time: " <<
Now().
As(unit)
518 <<
", Local time: " <<
m_ipv6->GetObject<
Node>()->GetLocalTime().As(unit)
519 <<
", IPv6 RIPng table" << std::endl;
523 *os <<
"Destination Next Hop Flag Met Ref Use If"
532 std::ostringstream dest;
533 std::ostringstream gw;
534 std::ostringstream mask;
535 std::ostringstream flags;
537 dest << route->
GetDest() <<
"/"
539 *os << std::setw(31) << dest.str();
541 *os << std::setw(27) << gw.str();
551 *os << std::setw(5) << flags.str();
592 iter->first->Close();
610 uint16_t longestMask = 0;
617 "Try to send on link-local multicast address, and no interface index is given!");
618 rtentry = Create<Ipv6Route>();
620 m_ipv6->SourceAddressSelection(
m_ipv6->GetInterfaceForDevice(interface), dst));
621 rtentry->SetDestination(dst);
623 rtentry->SetOutputDevice(interface);
637 NS_LOG_LOGIC(
"Searching for route to " << dst <<
", mask length " << maskLen);
641 NS_LOG_LOGIC(
"Found global network route " << j <<
", mask length " << maskLen);
646 if (maskLen < longestMask)
652 longestMask = maskLen;
656 rtentry = Create<Ipv6Route>();
663 m_ipv6->SourceAddressSelection(interfaceIdx, route->
GetDest()));
667 rtentry->SetSource(
m_ipv6->SourceAddressSelection(
674 m_ipv6->SourceAddressSelection(interfaceIdx, route->
GetDest()));
678 rtentry->SetDestination(route->
GetDest());
680 rtentry->SetOutputDevice(
m_ipv6->GetNetDevice(interfaceIdx));
688 NS_LOG_LOGIC(
"Matching route via " << rtentry->GetDestination() <<
" (through "
689 << rtentry->GetGateway() <<
") at the end");
701 NS_LOG_FUNCTION(
this << network << networkPrefix << nextHop << interface << prefixToUse);
705 NS_LOG_WARN(
"Ripng::AddNetworkRouteTo - Next hop should be link-local");
737 if (it->first == route)
742 if (it->second.IsRunning())
751 NS_ABORT_MSG(
"Ripng::InvalidateRoute - cannot find the route to update");
761 if (it->first == route)
768 NS_ABORT_MSG(
"Ripng::DeleteRoute - cannot find the route to delete");
779 NS_LOG_INFO(
"Received " << *packet <<
" from " << senderAddr);
782 uint16_t senderPort = senderAddr.
GetPort();
785 if (!packet->RemovePacketTag(interfaceInfo))
787 NS_ABORT_MSG(
"No incoming interface on RIPng message, aborting.");
790 Ptr<Node> node = this->GetObject<Node>();
795 if (!packet->RemovePacketTag(hoplimitTag))
797 NS_ABORT_MSG(
"No incoming Hop Count on RIPng message, aborting.");
801 int32_t interfaceForAddress =
m_ipv6->GetInterfaceForAddress(senderAddress);
802 if (interfaceForAddress != -1)
809 packet->RemoveHeader(hdr);
817 HandleRequests(hdr, senderAddress, senderPort, ipInterfaceIndex, hopLimit);
832 NS_LOG_FUNCTION(
this << senderAddress <<
int(senderPort) << incomingInterface <<
int(hopLimit)
835 std::list<RipNgRte> rtes = requestHdr.
GetRteList();
843 if (rtes.size() == 1 && senderAddress.
IsLinkLocal())
846 rtes.begin()->GetPrefixLen() == 0 && rtes.begin()->GetRouteMetric() ==
m_linkDown)
858 if (iter->second == incomingInterface)
860 sendingSocket = iter->first;
864 "HandleRequest - Impossible to find a socket to send the reply");
866 uint16_t mtu =
m_ipv6->GetMtu(incomingInterface);
874 p->RemovePacketTag(tag);
876 p->AddPacketTag(tag);
883 bool splitHorizoning = (rtIter->first->GetInterface() == incomingInterface);
887 rtIter->first->GetDestNetworkPrefix());
890 bool isDefaultRoute =
893 (rtIter->first->GetInterface() != incomingInterface));
895 if ((isGlobal || isDefaultRoute) &&
899 rte.
SetPrefix(rtIter->first->GetDestNetwork());
900 rte.
SetPrefixLen(rtIter->first->GetDestNetworkPrefix().GetPrefixLength());
921 p->RemoveHeader(hdr);
946 if (iter->second == incomingInterface)
948 sendingSocket = iter->first;
959 p->RemovePacketTag(tag);
961 p->AddPacketTag(tag);
966 for (std::list<RipNgRte>::iterator iter = rtes.begin(); iter != rtes.end(); iter++)
973 rtIter->first->GetDestNetworkPrefix());
979 Ipv6Address rtAddress = rtIter->first->GetDestNetwork();
980 rtAddress.
CombinePrefix(rtIter->first->GetDestNetworkPrefix());
982 if (requestedAddress == rtAddress)
984 iter->SetRouteMetric(rtIter->first->GetRouteMetric());
985 iter->SetRouteTag(rtIter->first->GetRouteTag());
995 iter->SetRouteTag(0);
1011 NS_LOG_FUNCTION(
this << senderAddress << incomingInterface <<
int(hopLimit) << hdr);
1016 "Ignoring an update message from an excluded interface: " << incomingInterface);
1022 NS_LOG_LOGIC(
"Ignoring an update message from a non-link-local source: " << senderAddress);
1026 if (hopLimit != 255)
1028 NS_LOG_LOGIC(
"Ignoring an update message with suspicious hop count: " <<
int(hopLimit));
1035 for (std::list<RipNgRte>::iterator iter = rtes.begin(); iter != rtes.end(); iter++)
1037 if (iter->GetRouteMetric() == 0 || iter->GetRouteMetric() >
m_linkDown)
1039 NS_LOG_LOGIC(
"Ignoring an update message with malformed metric: "
1040 <<
int(iter->GetRouteMetric()));
1043 if (iter->GetPrefixLen() > 128)
1045 NS_LOG_LOGIC(
"Ignoring an update message with malformed prefix length: "
1046 <<
int(iter->GetPrefixLen()));
1049 if (iter->GetPrefix().IsLocalhost() || iter->GetPrefix().IsLinkLocal() ||
1050 iter->GetPrefix().IsMulticast())
1052 NS_LOG_LOGIC(
"Ignoring an update message with wrong prefixes: " << iter->GetPrefix());
1057 bool changed =
false;
1059 for (std::list<RipNgRte>::iterator iter = rtes.begin(); iter != rtes.end(); iter++)
1066 uint8_t interfaceMetric = 1;
1071 uint16_t rteMetric = iter->GetRouteMetric() + interfaceMetric;
1080 if (it->first->GetDestNetwork() == rteAddr &&
1081 it->first->GetDestNetworkPrefix() == rtePrefix)
1084 if (rteMetric < it->
first->GetRouteMetric())
1086 if (senderAddress != it->first->GetGateway())
1099 it->first->SetRouteTag(iter->GetRouteTag());
1100 it->first->SetRouteChanged(
true);
1101 it->second.Cancel();
1108 else if (rteMetric == it->first->GetRouteMetric())
1110 if (senderAddress == it->first->GetGateway())
1112 it->second.Cancel();
1134 it->second.Cancel();
1143 else if (rteMetric > it->first->GetRouteMetric() &&
1144 senderAddress == it->first->GetGateway())
1146 it->second.Cancel();
1149 it->first->SetRouteMetric(rteMetric);
1151 it->first->SetRouteTag(iter->GetRouteTag());
1152 it->first->SetRouteChanged(
true);
1153 it->second.Cancel();
1169 NS_LOG_LOGIC(
"Received a RTE with new route, adding.");
1204 uint16_t mtu =
m_ipv6->GetMtu(interface);
1213 p->AddPacketTag(tag);
1220 bool splitHorizoning = (rtIter->first->GetInterface() == interface);
1223 rtIter->first->GetDestNetworkPrefix());
1226 <<
int(rtIter->first->IsRouteChanged()));
1229 bool isDefaultRoute =
1232 (rtIter->first->GetInterface() != interface));
1234 if ((isGlobal || isDefaultRoute) && (periodic || rtIter->first->IsRouteChanged()))
1237 rte.
SetPrefix(rtIter->first->GetDestNetwork());
1238 rte.
SetPrefixLen(rtIter->first->GetDestNetworkPrefix().GetPrefixLength());
1262 p->RemoveHeader(hdr);
1276 rtIter->first->SetRouteChanged(
false);
1287 NS_LOG_LOGIC(
"Skipping Triggered Update due to cooldown");
1348 std::map<uint32_t, uint8_t>::const_iterator iter =
m_interfaceMetrics.find(interface);
1351 return iter->second;
1374 p->RemovePacketTag(tag);
1376 p->AddPacketTag(tag);
1420 m_status(RIPNG_INVALID),
1437 m_status(RIPNG_INVALID),
1449 m_status(RIPNG_INVALID),
1461 if (
m_tag != routeTag)
1521 os << static_cast<const Ipv6RoutingTableEntry&>(rte);
a polymophic address class
bool IsNull() const
Check for null implementation.
Hold variables of type enum.
An identifier for simulation events.
void Cancel()
This method is syntactic sugar for the ns3::Simulator::Cancel method.
bool IsRunning() const
This method is syntactic sugar for !IsExpired().
static Inet6SocketAddress ConvertFrom(const Address &addr)
Convert the address to a InetSocketAddress.
uint16_t GetPort() const
Get the port.
Ipv6Address GetIpv6() const
Get the IPv6 address.
Describes an IPv6 address.
bool IsLinkLocal() const
If the IPv6 address is a link-local address (fe80::/64).
static Ipv6Address GetAny()
Get the "any" (::) Ipv6Address.
bool IsLinkLocalMulticast() const
If the IPv6 address is link-local multicast (ff02::/16).
static Ipv6Address GetZero()
Get the 0 (::) Ipv6Address.
bool IsMulticast() const
If the IPv6 address is multicast (ff00::/8).
bool IsAny() const
If the IPv6 address is the "Any" address.
Ipv6Address CombinePrefix(const Ipv6Prefix &prefix) const
Combine this address with a prefix.
IPv6 address associated with an interface.
Ipv6InterfaceAddress::Scope_e GetScope() const
Get address scope.
@ LINKLOCAL
Link-local address (fe80::/64)
@ GLOBAL
Global address (2000::/3)
This class implements a tag that carries socket ancillary data to the socket interface.
uint32_t GetRecvIf() const
Get the tag's receiving interface.
Describes an IPv6 prefix.
uint8_t GetPrefixLength() const
Get prefix length.
static Ipv6Prefix GetZero()
Get the zero prefix ( /0).
bool IsMatch(Ipv6Address a, Ipv6Address b) const
If the Address match the type.
Abstract base class for IPv6 routing protocols.
A record of an IPv6 route.
Ipv6Address GetDest() const
Get the destination.
Ipv6Address GetDestNetwork() const
Get the destination network.
Ipv6Address GetPrefixToUse() const
Get the prefix to use (for multihomed link).
bool IsHost() const
Is the route entry correspond to a host ?
uint32_t GetInterface() const
Get the interface index.
Ipv6Prefix GetDestNetworkPrefix() const
Get the destination prefix.
Ipv6Address GetGateway() const
Get the gateway.
bool IsGateway() const
Is it the gateway ?
static std::string FindName(Ptr< Object > object)
Given a pointer to an object, look to see if that object has a name associated with it and,...
virtual void DoInitialize()
Initialize() implementation.
virtual void DoDispose()
Destructor implementation.
Smart pointer class similar to boost::intrusive_ptr.
void SetStream(int64_t stream)
Specifies the stream number for the RngStream.
RIPng Routing Protocol, defined in RFC 2080.
Ptr< Socket > m_multicastRecvSocket
multicast receive socket
void NotifyInterfaceUp(uint32_t interface) override
Notify when specified interface goes UP.
void NotifyAddAddress(uint32_t interface, Ipv6InterfaceAddress address) override
Notify when specified interface add an address.
void NotifyAddRoute(Ipv6Address dst, Ipv6Prefix mask, Ipv6Address nextHop, uint32_t interface, Ipv6Address prefixToUse=Ipv6Address::GetZero()) override
Notify a new route.
void DoSendRouteUpdate(bool periodic)
Send Routing Updates on all interfaces.
Time m_startupDelay
Random delay before protocol startup.
void DoDispose() override
Dispose this object.
std::list< std::pair< RipNgRoutingTableEntry *, EventId > >::const_iterator RoutesCI
Const Iterator for container for the network routes.
SplitHorizonType_e m_splitHorizonStrategy
Split Horizon strategy.
@ SPLIT_HORIZON
Split Horizon.
@ POISON_REVERSE
Poison Reverse Split Horizon.
@ NO_SPLIT_HORIZON
No Split Horizon.
EventId m_nextTriggeredUpdate
Next Triggered Update event.
std::list< std::pair< RipNgRoutingTableEntry *, EventId > >::iterator RoutesI
Iterator for container for the network routes.
void NotifyRemoveAddress(uint32_t interface, Ipv6InterfaceAddress address) override
Notify when specified interface add an address.
Time m_minTriggeredUpdateDelay
Min cooldown delay after a Triggered Update.
void SetInterfaceExclusions(std::set< uint32_t > exceptions)
Set the set of interface excluded from the protocol.
Ptr< Ipv6Route > RouteOutput(Ptr< Packet > p, const Ipv6Header &header, Ptr< NetDevice > oif, Socket::SocketErrno &sockerr) override
Query routing cache for an existing route, for an outbound packet.
EventId m_nextUnsolicitedUpdate
Next Unsolicited Update event.
uint8_t m_linkDown
Link down value.
Time m_maxTriggeredUpdateDelay
Max cooldown delay after a Triggered Update.
void DoInitialize() override
Start protocol operation.
bool m_initialized
flag to allow socket's late-creation.
SocketList m_unicastSocketList
list of sockets for unicast messages (socket, interface index)
std::map< Ptr< Socket >, uint32_t >::iterator SocketListI
Socket list type iterator.
uint8_t GetInterfaceMetric(uint32_t interface) const
Get the metric for an interface.
bool RouteInput(Ptr< const Packet > p, const Ipv6Header &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)
Time m_unsolicitedUpdate
time between two Unsolicited Routing Updates
std::set< uint32_t > m_interfaceExclusions
Set of excluded interfaces.
void SetInterfaceMetric(uint32_t interface, uint8_t metric)
Set the metric for an interface.
int64_t AssignStreams(int64_t stream)
Assign a fixed random variable stream number to the random variables used by this model.
void DeleteRoute(RipNgRoutingTableEntry *route)
Delete a route.
void AddNetworkRouteTo(Ipv6Address network, Ipv6Prefix networkPrefix, Ipv6Address nextHop, uint32_t interface, Ipv6Address prefixToUse)
Add route to network.
Time m_garbageCollectionDelay
Delay before deleting an INVALID route.
std::map< uint32_t, uint8_t > m_interfaceMetrics
Map of interface metrics.
void SendRouteRequest()
Send Routing Request on all interfaces.
void NotifyInterfaceDown(uint32_t interface) override
Notify when specified interface goes DOWN.
Ptr< Ipv6 > m_ipv6
IPv6 reference.
Routes m_routes
the forwarding table for network.
std::set< uint32_t > GetInterfaceExclusions() const
Get the set of interface excluded from the protocol.
void SendTriggeredRouteUpdate()
Send Triggered Routing Updates on all interfaces.
void HandleRequests(RipNgHeader hdr, Ipv6Address senderAddress, uint16_t senderPort, uint32_t incomingInterface, uint8_t hopLimit)
Handle RIPng requests.
Ptr< UniformRandomVariable > m_rng
Rng stream.
void HandleResponses(RipNgHeader hdr, Ipv6Address senderAddress, uint32_t incomingInterface, uint8_t hopLimit)
Handle RIPng responses.
void NotifyRemoveRoute(Ipv6Address dst, Ipv6Prefix mask, Ipv6Address nextHop, uint32_t interface, Ipv6Address prefixToUse=Ipv6Address::GetZero()) override
Notify route removing.
static TypeId GetTypeId()
Get the type ID.
void InvalidateRoute(RipNgRoutingTableEntry *route)
Invalidate a route.
void SetIpv6(Ptr< Ipv6 > ipv6) override
Typically, invoked directly or indirectly from ns3::Ipv6::SetRoutingProtocol.
void Receive(Ptr< Socket > socket)
Receive RIPng packets.
void AddDefaultRouteTo(Ipv6Address nextHop, uint32_t interface)
Add a default route to the router through the nextHop located on interface.
Time m_timeoutDelay
Delay before invalidating a route.
void SendUnsolicitedRouteUpdate()
Send Unsolicited Routing Updates on all interfaces.
void PrintRoutingTable(Ptr< OutputStreamWrapper > stream, Time::Unit unit=Time::S) const override
Print the Routing Table entries.
Ptr< Ipv6Route > Lookup(Ipv6Address dest, bool setSource, Ptr< NetDevice >=nullptr)
Lookup in the forwarding table for destination.
RipNg Routing Table Entry.
bool IsRouteChanged() const
Get the route changed status.
uint16_t GetRouteTag() const
Get the route tag.
bool m_changed
route has been updated
void SetRouteTag(uint16_t routeTag)
Set the route tag.
uint8_t GetRouteMetric() const
Get the route metric.
void SetRouteMetric(uint8_t routeMetric)
Set the route metric.
uint8_t m_metric
route metric
Status_e m_status
route status
Status_e GetRouteStatus() const
Get the route status.
void SetRouteChanged(bool changed)
Set the route as changed.
~RipNgRoutingTableEntry() override
void SetRouteStatus(Status_e status)
Set the route status.
RipNg Routing Table Entry (RTE) - see RFC 2080
void SetPrefix(Ipv6Address prefix)
Set the prefix.
void SetPrefixLen(uint8_t prefixLen)
Set the prefix length.
void SetRouteMetric(uint8_t routeMetric)
Set the route metric.
uint32_t GetSerializedSize() const override
Get the serialized size of the packet.
void SetRouteTag(uint16_t routeTag)
Set the route tag.
static EventId Schedule(const Time &delay, FUNC f, Ts &&... args)
Schedule an event to expire after delay.
static Time GetDelayLeft(const EventId &id)
Get the remaining time until this event will execute.
void SetRecvPktInfo(bool flag)
Enable/Disable receive packet information to socket.
void SetRecvCallback(Callback< void, Ptr< Socket > > receivedData)
Notify application when new data is available to be read.
static Ptr< Socket > CreateSocket(Ptr< Node > node, TypeId tid)
This method wraps the creation of sockets that is performed on a given node by a SocketFactory specif...
virtual int Close()=0
Close a socket.
SocketErrno
Enumeration of the possible errors returned by a socket.
virtual int Bind(const Address &address)=0
Allocate a local endpoint for this socket.
void SetIpv6RecvHopLimit(bool ipv6RecvHopLimit)
Tells a socket to pass information about IPv6 Hop Limit up the stack.
This class implements a tag that carries the socket-specific HOPLIMIT of a packet to the IPv6 layer.
uint8_t GetHopLimit() const
Get the tag's Hop Limit.
void SetHopLimit(uint8_t hopLimit)
Set the tag's Hop Limit.
Simulation virtual time values and global simulation resolution.
TimeWithUnit As(const Unit unit=Time::AUTO) const
Attach a unit to a Time, to facilitate output in a specific unit.
double GetSeconds() const
Get an approximation of the time stored in this instance in the indicated unit.
Unit
The unit to use to interpret a number representing time.
AttributeValue implementation for Time.
a unique identifier for an interface.
static TypeId LookupByName(std::string name)
Get a TypeId by name.
TypeId SetParent(TypeId tid)
Set the parent TypeId.
Hold an unsigned integer type.
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file,...
#define NS_ASSERT_MSG(condition, message)
At runtime, in debugging builds, if this condition is not true, the program prints the message to out...
Ptr< const AttributeAccessor > MakeEnumAccessor(T1 a1)
Ptr< const AttributeChecker > MakeTimeChecker()
Helper to make an unbounded Time checker.
Ptr< const AttributeAccessor > MakeTimeAccessor(T1 a1)
Ptr< const AttributeAccessor > MakeUintegerAccessor(T1 a1)
#define NS_ABORT_MSG(msg)
Unconditional abnormal program termination with a message.
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
#define NS_LOG_DEBUG(msg)
Use NS_LOG to output a message of level LOG_DEBUG.
#define NS_LOG_LOGIC(msg)
Use NS_LOG to output a message of level LOG_LOGIC.
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
#define NS_LOG_WARN(msg)
Use NS_LOG to output a message of level LOG_WARN.
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system.
Time Now()
create an ns3::Time instance which contains the current simulation time.
Time Seconds(double value)
Construct a Time in the indicated unit.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Callback< R, Args... > MakeCallback(R(T::*memPtr)(Args...), OBJ objPtr)
Build Callbacks for class method members which take varying numbers of arguments and potentially retu...
std::ostream & operator<<(std::ostream &os, const Angles &a)
Ptr< const AttributeChecker > MakeEnumChecker(int v, std::string n, Ts... args)
Make an EnumChecker pre-configured with a set of allowed values by name.