31#include "ns3/boolean.h"
32#include "ns3/callback.h"
33#include "ns3/ipv4-address.h"
35#include "ns3/net-device.h"
37#include "ns3/object-vector.h"
38#include "ns3/packet.h"
39#include "ns3/socket.h"
40#include "ns3/string.h"
41#include "ns3/trace-source-accessor.h"
42#include "ns3/traffic-control-layer.h"
43#include "ns3/uinteger.h"
58 TypeId(
"ns3::Ipv4L3Protocol")
60 .SetGroupName(
"Internet")
62 .AddAttribute(
"DefaultTtl",
63 "The TTL value set by default on "
64 "all outgoing packets generated on this node.",
67 MakeUintegerChecker<uint8_t>())
68 .AddAttribute(
"FragmentExpirationTimeout",
69 "When this timeout expires, the fragments "
70 "will be cleared from the buffer.",
74 .AddAttribute(
"EnableDuplicatePacketDetection",
75 "Enable multicast duplicate packet detection based on RFC 6621",
79 .AddAttribute(
"DuplicateExpire",
80 "Expiration delay for duplicate cache entries",
84 .AddAttribute(
"PurgeExpiredPeriod",
85 "Time between purges of expired duplicate packet entries, "
86 "0 means never purge",
91 "Send ipv4 packet to outgoing interface.",
93 "ns3::Ipv4L3Protocol::TxRxTracedCallback")
95 "Receive ipv4 packet from incoming interface.",
97 "ns3::Ipv4L3Protocol::TxRxTracedCallback")
98 .AddTraceSource(
"Drop",
101 "ns3::Ipv4L3Protocol::DropTracedCallback")
102 .AddAttribute(
"InterfaceList",
103 "The set of Ipv4 interfaces associated to this Ipv4 stack.",
106 MakeObjectVectorChecker<Ipv4Interface>())
108 .AddTraceSource(
"SendOutgoing",
109 "A newly-generated packet by this node is "
110 "about to be queued for transmission",
112 "ns3::Ipv4L3Protocol::SentTracedCallback")
113 .AddTraceSource(
"UnicastForward",
114 "A unicast IPv4 packet was received by this node "
115 "and is being forwarded to another node",
117 "ns3::Ipv4L3Protocol::SentTracedCallback")
118 .AddTraceSource(
"MulticastForward",
119 "A multicast IPv4 packet was received by this node "
120 "and is being forwarded to another node",
122 "ns3::Ipv4L3Protocol::SentTracedCallback")
123 .AddTraceSource(
"LocalDeliver",
124 "An IPv4 packet was received by/for this node, "
125 "and it is being forward up the stack",
127 "ns3::Ipv4L3Protocol::SentTracedCallback")
151 L4ListKey_t key = std::make_pair(protocol->GetProtocolNumber(), -1);
154 NS_LOG_WARN(
"Overwriting default protocol " <<
int(protocol->GetProtocolNumber()));
164 L4ListKey_t key = std::make_pair(protocol->GetProtocolNumber(), interfaceIndex);
167 NS_LOG_WARN(
"Overwriting protocol " <<
int(protocol->GetProtocolNumber())
168 <<
" on interface " <<
int(interfaceIndex));
178 L4ListKey_t key = std::make_pair(protocol->GetProtocolNumber(), -1);
182 NS_LOG_WARN(
"Trying to remove an non-existent default protocol "
183 <<
int(protocol->GetProtocolNumber()));
196 L4ListKey_t key = std::make_pair(protocol->GetProtocolNumber(), interfaceIndex);
200 NS_LOG_WARN(
"Trying to remove an non-existent protocol "
201 <<
int(protocol->GetProtocolNumber()) <<
" on interface "
202 <<
int(interfaceIndex));
224 L4List_t::const_iterator i;
225 if (interfaceIndex >= 0)
228 key = std::make_pair(protocolNumber, interfaceIndex);
236 key = std::make_pair(protocolNumber, -1);
289 Ptr<Node> node = this->GetObject<Node>();
338 it->second =
nullptr;
374 device = CreateObject<LoopbackNetDevice>();
377 interface->SetDevice(device);
378 interface->SetNode(
m_node);
381 interface->AddAddress(ifaceAddr);
421 tc->RegisterProtocolHandler(
428 interface->SetDevice(device);
429 interface->SetTrafficControl(tc);
470 for (
uint32_t j = 0; j < (*i)->GetNAddresses(); j++)
472 if ((*i)->GetAddress(j).GetLocal() == address)
490 for (
uint32_t j = 0; j < (*i)->GetNAddresses(); j++)
492 if ((*i)->GetAddress(j).GetLocal().CombineMask(mask) == address.CombineMask(mask))
510 return (*iter).second;
526 NS_LOG_LOGIC(
"For me (destination " << address <<
" match)");
536 if (address.IsMulticast())
539 if (MulticastCheckGroup(iif, address))
547 if (address.IsBroadcast())
567 <<
" match) on another interface");
573 NS_LOG_LOGIC(
"For me (interface broadcast address on another interface)");
590 NS_LOG_FUNCTION(
this << device << p << protocol << from << to << packetType);
594 int32_t interface = GetInterfaceForDevice(device);
595 NS_ASSERT_MSG(interface != -1,
"Received a packet from an interface that is not known to IPv4");
601 if (ipv4Interface->IsUp())
603 m_rxTrace(packet,
this, interface);
607 NS_LOG_LOGIC(
"Dropping received packet -- interface is down");
609 packet->RemoveHeader(ipHeader);
610 m_dropTrace(ipHeader, packet, DROP_INTERFACE_DOWN,
this, interface);
615 if (Node::ChecksumEnabled())
619 packet->RemoveHeader(ipHeader);
624 packet->RemoveAtEnd(packet->GetSize() - ipHeader.
GetPayloadSize());
629 NS_LOG_LOGIC(
"Dropping received packet -- checksum not ok");
630 m_dropTrace(ipHeader, packet, DROP_BAD_CHECKSUM,
this, interface);
652 std::list<ArpCache::Entry*> entryList = arpCache->LookupInverse(from);
653 std::list<ArpCache::Entry*>::iterator iter;
654 for (iter = entryList.begin(); iter != entryList.end(); iter++)
656 if ((*iter)->IsAlive())
658 (*iter)->UpdateSeen();
664 for (SocketList::iterator i = m_sockets.begin(); i != m_sockets.end(); ++i)
668 socket->ForwardUp(packet, ipHeader, ipv4Interface);
674 m_dropTrace(ipHeader, packet, DROP_DUPLICATE,
this, interface);
678 NS_ASSERT_MSG(m_routingProtocol,
"Need a routing protocol object to process packets");
679 if (!m_routingProtocol->RouteInput(packet, ipHeader, device, m_ucb, m_mcb, m_lcb, m_ecb))
681 NS_LOG_WARN(
"No route found for forwarding packet. Drop.");
682 m_dropTrace(ipHeader, packet, DROP_NO_ROUTE,
this, interface);
718 NS_LOG_LOGIC(
"Testing address " << ad <<
" with subnet-directed broadcast "
758 packetCopy->AddHeader(ipHeader);
772 bool mayFragment =
true;
779 bool ipTtlTagFound = packet->RemovePacketTag(ipTtlTag);
787 bool ipTosTagFound = packet->RemovePacketTag(ipTosTag);
795 BuildHeader(source, destination, protocol, packet->GetSize(), ttl, tos, mayFragment);
810 if (!route->GetGateway().IsInitialized())
816 NS_FATAL_ERROR(
"Ipv4L3Protocol::Send case 1a: packet passed with a route but the "
817 "Gateway address is uninitialized. This case not yet implemented.");
821 NS_LOG_LOGIC(
"Ipv4L3Protocol::Send case 1b: passed in with route and valid gateway");
835 NS_LOG_LOGIC(
"Ipv4L3Protocol::Send case 2: limited broadcast - no route");
837 for (Ipv4InterfaceList::iterator ifaceIter =
m_interfaces.begin();
839 ifaceIter++, ifaceIndex++)
843 bool sendIt = source.
IsAny();
845 for (
uint32_t index = 0; !sendIt && index < outInterface->GetNAddresses(); index++)
847 if (outInterface->GetAddress(index).GetLocal() == source)
857 route->SetDestination(destination);
859 route->SetSource(source);
860 route->SetOutputDevice(outInterface->GetDevice());
862 Send(pktCopyWithTags, source, destination, protocol, route);
869 for (Ipv4InterfaceList::iterator ifaceIter =
m_interfaces.begin();
884 NS_LOG_LOGIC(
"Ipv4L3Protocol::Send case 3: subnet directed bcast to "
885 << ifAddr.
GetLocal() <<
" - no route");
888 route->SetDestination(destination);
890 route->SetSource(source);
891 route->SetOutputDevice(outInterface->GetDevice());
893 Send(pktCopyWithTags, source, destination, protocol, route);
900 NS_LOG_LOGIC(
"Ipv4L3Protocol::Send case 4: not broadcast and passed in with no route "
907 newRoute =
m_routingProtocol->RouteOutput(pktCopyWithTags, ipHeader, oif, errno_);
911 NS_LOG_ERROR(
"Ipv4L3Protocol::Send: m_routingProtocol == 0");
916 Send(pktCopyWithTags, source, destination, protocol, newRoute);
931 uint64_t src = source.
Get();
932 uint64_t dst = destination.
Get();
933 uint64_t srcDst = dst | (src << 32);
934 std::pair<uint64_t, uint8_t> key = std::make_pair(srcDst, protocol);
942 uint16_t payloadSize,
947 NS_LOG_FUNCTION(
this << source << destination << (uint16_t)protocol << payloadSize
948 << (uint16_t)ttl << (uint16_t)tos << mayFragment);
957 uint64_t src = source.
Get();
958 uint64_t dst = destination.
Get();
959 uint64_t srcDst = dst | (src << 32);
960 std::pair<uint64_t, uint8_t> key = std::make_pair(srcDst, protocol);
996 int32_t interface = GetInterfaceForDevice(outDev);
999 NS_LOG_LOGIC(
"Send via NetDevice ifIndex " << outDev->GetIfIndex() <<
" ipv4InterfaceIndex "
1003 std::string targetLabel;
1004 if (route->GetGateway().IsAny())
1007 targetLabel =
"destination";
1011 target = route->GetGateway();
1012 targetLabel =
"gateway";
1015 if (outInterface->IsUp())
1017 NS_LOG_LOGIC(
"Send to " << targetLabel <<
" " << target);
1018 if (packet->GetSize() + ipHeader.
GetSerializedSize() > outInterface->GetDevice()->GetMtu())
1020 std::list<Ipv4PayloadHeaderPair> listFragments;
1021 DoFragmentation(packet, ipHeader, outInterface->GetDevice()->GetMtu(), listFragments);
1022 for (std::list<Ipv4PayloadHeaderPair>::iterator it = listFragments.begin();
1023 it != listFragments.end();
1027 CallTxTrace(it->second, it->first,
this, interface);
1028 outInterface->Send(it->first, it->second, target);
1033 CallTxTrace(ipHeader, packet,
this, interface);
1034 outInterface->Send(packet, ipHeader, target);
1048 std::map<uint32_t, uint32_t> ttlMap = mrtentry->GetOutputTtlMap();
1049 std::map<uint32_t, uint32_t>::iterator mapIter;
1051 for (mapIter = ttlMap.begin(); mapIter != ttlMap.end(); mapIter++)
1059 if (ipHeader.
GetTtl() == 0)
1065 NS_LOG_LOGIC(
"Forward multicast via interface " << interface);
1067 rtentry->SetSource(ipHeader.
GetSource());
1088 if (ipHeader.
GetTtl() == 0)
1094 icmp->SendTimeExceededTtl(ipHeader, packet,
false);
1102 packet->RemovePacketTag(priorityTag);
1108 packet->AddPacketTag(priorityTag);
1124 NS_LOG_LOGIC(
"Received a fragment, processing " << *p);
1125 bool isPacketComplete;
1127 if (!isPacketComplete)
1131 NS_LOG_LOGIC(
"Got last fragment, Packet is complete " << *p);
1159 bool subnetDirected =
false;
1167 subnetDirected =
true;
1170 if (!subnetDirected)
1172 GetIcmp()->SendDestUnreachPort(ipHeader, copy);
1183 bool retVal = interface->AddAddress(address);
1184 if (m_routingProtocol)
1186 m_routingProtocol->NotifyAddAddress(i, address);
1196 return interface->GetAddress(addressIndex);
1204 return iface->GetNAddresses();
1215 if (m_routingProtocol)
1217 m_routingProtocol->NotifyRemoveAddress(i, address);
1238 if (m_routingProtocol)
1240 m_routingProtocol->NotifyRemoveAddress(i, ifAddr);
1265 if (!
test.IsSecondary())
1267 return test.GetLocal();
1331 NS_LOG_WARN(
"Could not find source address for " << dst <<
" and scope " << scope
1332 <<
", returning 0");
1341 interface->SetMetric(metric);
1349 return interface->GetMetric();
1357 return interface->GetDevice()->GetMtu();
1365 return interface->IsUp();
1378 if (interface->GetDevice()->GetMtu() >= 68)
1382 if (m_routingProtocol)
1384 m_routingProtocol->NotifyInterfaceUp(i);
1392 <<
" is set to be down for IPv4. Reason: not respecting minimum IPv4 MTU (68 octets)");
1401 interface->SetDown();
1403 if (m_routingProtocol)
1405 m_routingProtocol->NotifyInterfaceDown(ifaceIndex);
1414 NS_LOG_LOGIC(
"Forwarding state: " << interface->IsForwarding());
1415 return interface->IsForwarding();
1423 interface->SetForwarding(val);
1440 (*i)->SetForwarding(forward);
1471 NS_LOG_LOGIC(
"Route input failure-- dropping packet to " << ipHeader <<
" with errno "
1482 std::list<Ipv4PayloadHeaderPair>& listFragments)
1494 "IPv4 fragmentation implementation only works without option headers.");
1496 uint16_t offset = 0;
1497 bool moreFragment =
true;
1500 uint32_t currentFragmentablePartSize = 0;
1507 NS_LOG_LOGIC(
"Fragmenting - Target Size: " << fragmentSize);
1513 if (p->GetSize() > offset + fragmentSize)
1515 moreFragment =
true;
1516 currentFragmentablePartSize = fragmentSize;
1521 moreFragment =
false;
1522 currentFragmentablePartSize = p->GetSize() - offset;
1523 if (!isLastFragment)
1533 NS_LOG_LOGIC(
"Fragment creation - " << offset <<
", " << currentFragmentablePartSize);
1534 Ptr<Packet> fragment = p->CreateFragment(offset, currentFragmentablePartSize);
1535 NS_LOG_LOGIC(
"Fragment created - " << offset <<
", " << fragment->GetSize());
1547 NS_LOG_LOGIC(
"New fragment Header " << fragmentHeader);
1549 std::ostringstream oss;
1550 oss << fragmentHeader;
1551 fragment->Print(oss);
1555 listFragments.emplace_back(fragment, fragmentHeader);
1557 offset += currentFragmentablePartSize;
1559 }
while (moreFragment);
1567 uint64_t addressCombination =
1575 key.first = addressCombination;
1576 key.second = idProto;
1580 MapFragments_t::iterator it =
m_fragments.find(key);
1583 fragments = Create<Fragments>();
1584 m_fragments.insert(std::make_pair(key, fragments));
1587 fragments->SetTimeoutIter(iter);
1591 fragments = it->second;
1594 NS_LOG_LOGIC(
"Adding fragment - Size: " << packet->GetSize()
1599 if (fragments->IsEntire())
1601 packet = fragments->GetPacket();
1603 fragments =
nullptr;
1619 uint16_t fragmentOffset,
1624 std::list<std::pair<Ptr<Packet>, uint16_t>>::iterator it;
1628 if (it->second > fragmentOffset)
1636 m_moreFragment = moreFragment;
1647 bool ret = !m_moreFragment && !
m_fragments.empty();
1651 uint16_t lastEndOffset = 0;
1658 NS_LOG_LOGIC(
"Checking overlaps " << lastEndOffset <<
" - " << it->second);
1660 if (lastEndOffset < it->
second)
1666 uint16_t fragmentEnd = it->first->GetSize() + it->second;
1667 lastEndOffset = std::max(lastEndOffset, fragmentEnd);
1679 std::list<std::pair<Ptr<Packet>, uint16_t>>::const_iterator it =
m_fragments.begin();
1682 uint16_t lastEndOffset = p->GetSize();
1687 if (lastEndOffset > it->second)
1693 uint32_t newStart = lastEndOffset - it->second;
1694 if (it->first->GetSize() > newStart)
1696 uint32_t newSize = it->first->GetSize() - newStart;
1697 Ptr<Packet> tempFragment = it->first->CreateFragment(newStart, newSize);
1698 p->AddAtEnd(tempFragment);
1704 p->AddAtEnd(it->first);
1706 lastEndOffset = p->GetSize();
1717 std::list<std::pair<Ptr<Packet>, uint16_t>>::const_iterator it =
m_fragments.begin();
1720 uint16_t lastEndOffset = 0;
1729 if (lastEndOffset > it->second)
1731 uint32_t newStart = lastEndOffset - it->second;
1732 uint32_t newSize = it->first->GetSize() - newStart;
1733 Ptr<Packet> tempFragment = it->first->CreateFragment(newStart, newSize);
1734 p->AddAtEnd(tempFragment);
1736 else if (lastEndOffset == it->second)
1739 p->AddAtEnd(it->first);
1741 lastEndOffset = p->GetSize();
1750 m_timeoutIter = iter;
1756 return m_timeoutIter;
1764 MapFragments_t::iterator it =
m_fragments.find(key);
1765 Ptr<Packet> packet = it->second->GetPartialPacket();
1768 if (packet->GetSize() > 8)
1771 icmp->SendTimeExceededTtl(ipHeader, packet,
true);
1776 it->second =
nullptr;
1793 uint64_t hash =
id << 32;
1805 pkt->AddHeader(header);
1807 std::ostringstream oss(std::ios_base::binary);
1808 pkt->CopyData(&oss, pkt->GetSize());
1809 std::string bytes = oss.str();
1811 NS_ASSERT_MSG(bytes.size() >= 20,
"Degenerate header serialization");
1815 bytes[6] = bytes[7] = 0;
1817 bytes[10] = bytes[11] = 0;
1824 hash |= (uint64_t)
Hash32(bytes);
1835 NS_LOG_DEBUG(
"Packet " << p->GetUid() <<
" key = (" << std::hex << std::get<0>(key) <<
", "
1836 << std::dec << +std::get<1>(key) <<
", " << std::get<2>(key) <<
", "
1837 << std::get<3>(key) <<
")");
1840 DupMap_t::iterator iter;
1856 DupMap_t::size_type n = 0;
1858 auto iter =
m_dups.cbegin();
1859 while (iter !=
m_dups.cend())
1861 if (iter->second < expire)
1863 NS_LOG_LOGIC(
"Remove key = (" << std::hex << std::get<0>(iter->first) <<
", "
1864 << std::dec << +std::get<1>(iter->first) <<
", "
1865 << std::get<2>(iter->first) <<
", "
1866 << std::get<3>(iter->first) <<
")");
1867 iter =
m_dups.erase(iter);
1876 NS_LOG_DEBUG(
"Purged " << n <<
" expired duplicate entries out of " << (n +
m_dups.size()));
a polymophic address class
A record that that holds information about an ArpCache entry.
void UpdateSeen()
Update the entry when seeing a packet.
void Receive(Ptr< NetDevice > device, Ptr< const Packet > p, uint16_t protocol, const Address &from, const Address &to, NetDevice::PacketType packetType)
Receive a packet.
static const uint16_t PROT_NUMBER
ARP protocol number (0x0806)
AttributeValue implementation for Boolean.
void Cancel()
This method is syntactic sugar for the ns3::Simulator::Cancel method.
bool IsRunning() const
This method is syntactic sugar for !IsExpired().
This is the implementation of the ICMP protocol as described in RFC 792.
static uint16_t GetStaticProtocolNumber()
Get the protocol number.
Ipv4 addresses are stored in host order in this class.
static Ipv4Address GetLoopback()
bool IsSubnetDirectedBroadcast(const Ipv4Mask &mask) const
Generate subnet-directed broadcast address corresponding to mask.
Ipv4Address CombineMask(const Ipv4Mask &mask) const
Combine this address with a network mask.
uint32_t Get() const
Get the host-order 32-bit IP address.
static Ipv4Address GetAny()
bool IsLocalMulticast() const
Access to the IPv4 forwarding table, interfaces, and configuration.
a class to store IPv4 address information on an interface
Ipv4Mask GetMask() const
Get the network mask.
InterfaceAddressScope_e
Address scope.
Ipv4InterfaceAddress::InterfaceAddressScope_e GetScope() const
Get address scope.
Ipv4Address GetLocal() const
Get the local address.
bool IsSecondary() const
Check if the address is a secondary address.
Ipv4Address GetBroadcast() const
Get the broadcast address.
The IPv4 representation of a network interface.
void SetNode(Ptr< Node > node)
Set node associated with interface.
Ptr< NetDevice > GetDevice() const
bool IsEntire() const
If all fragments have been added.
Ptr< Packet > GetPartialPacket() const
Get the complete part of the packet.
FragmentsTimeoutsListI_t GetTimeoutIter()
Get the Timeout iterator.
void AddFragment(Ptr< Packet > fragment, uint16_t fragmentOffset, bool moreFragment)
Add a fragment.
Ptr< Packet > GetPacket() const
Get the entire packet.
void SetTimeoutIter(FragmentsTimeoutsListI_t iter)
Set the Timeout iterator.
Implement the IPv4 layer.
static const uint16_t PROT_NUMBER
Protocol number (0x0800)
std::tuple< uint64_t, uint8_t, Ipv4Address, Ipv4Address > DupTuple_t
IETF RFC 6621, Section 6.2 de-duplication w/o IPSec RFC 6621 recommended duplicate packet tuple: {IPV...
void CallTxTrace(const Ipv4Header &ipHeader, Ptr< Packet > packet, Ptr< Ipv4 > ipv4, uint32_t interface)
Make a copy of the packet, add the header and invoke the TX trace callback.
@ DROP_NO_ROUTE
No route to host.
@ DROP_TTL_EXPIRED
Packet TTL has expired.
@ DROP_ROUTE_ERROR
Route error.
@ DROP_FRAGMENT_TIMEOUT
Fragment timeout exceeded.
void DecreaseIdentification(Ipv4Address source, Ipv4Address destination, uint8_t protocol)
Decrease the identification value for a dropped or recursed packet.
Ipv4InterfaceList m_interfaces
List of IPv4 interfaces.
void DeleteRawSocket(Ptr< Socket > socket) override
Deletes a particular raw socket.
MapFragments_t m_fragments
Fragmented packets.
void LocalDeliver(Ptr< const Packet > p, const Ipv4Header &ip, uint32_t iif)
Deliver a packet.
bool IsDestinationAddress(Ipv4Address address, uint32_t iif) const override
Determine whether address and interface corresponding to received packet can be accepted for local de...
std::pair< uint64_t, uint32_t > FragmentKey_t
Key identifying a fragmented packet.
Time m_expire
duplicate entry expiration delay
Ipv4RoutingProtocol::ErrorCallback m_ecb
Error callback.
~Ipv4L3Protocol() override
bool m_ipForward
Forwarding packets (i.e.
void Receive(Ptr< NetDevice > device, Ptr< const Packet > p, uint16_t protocol, const Address &from, const Address &to, NetDevice::PacketType packetType)
Lower layer calls this method after calling L3Demux::Lookup The ARP subclass needs to know from which...
void SetUp(uint32_t i) override
uint32_t GetNInterfaces() const override
Ipv4Header BuildHeader(Ipv4Address source, Ipv4Address destination, uint8_t protocol, uint16_t payloadSize, uint8_t ttl, uint8_t tos, bool mayFragment)
Construct an IPv4 header.
void RouteInputError(Ptr< const Packet > p, const Ipv4Header &ipHeader, Socket::SocketErrno sockErrno)
Fallback when no route is found.
void SetMetric(uint32_t i, uint16_t metric) override
void DoDispose() override
Destructor implementation.
void Remove(Ptr< IpL4Protocol > protocol) override
void SetIpForward(bool forward) override
Set or unset the IP forwarding state.
bool AddAddress(uint32_t i, Ipv4InterfaceAddress address) override
TracedCallback< const Ipv4Header &, Ptr< const Packet >, uint32_t > m_unicastForwardTrace
Trace of unicast forwarded packets.
bool GetWeakEsModel() const override
Get the Weak Es Model status.
TracedCallback< const Ipv4Header &, Ptr< const Packet >, uint32_t > m_localDeliverTrace
Trace of locally delivered packets.
bool IsUnicast(Ipv4Address ad) const
Check if an IPv4 address is unicast according to the node.
void HandleFragmentsTimeout(FragmentKey_t key, Ipv4Header &ipHeader, uint32_t iif)
Process the timeout for packet fragments.
uint16_t GetMtu(uint32_t i) const override
Ptr< Icmpv4L4Protocol > GetIcmp() const
Get ICMPv4 protocol.
Ptr< IpL4Protocol > GetProtocol(int protocolNumber) const override
void RemoveDuplicates()
Remove expired duplicates packet entry.
void DoFragmentation(Ptr< Packet > packet, const Ipv4Header &ipv4Header, uint32_t outIfaceMtu, std::list< Ipv4PayloadHeaderPair > &listFragments)
Fragment a packet.
SocketList m_sockets
List of IPv4 raw sockets.
bool m_enableDpd
Enable multicast duplicate packet detection.
std::map< std::pair< uint64_t, uint8_t >, uint16_t > m_identification
Identification (for each {src, dst, proto} tuple)
bool IsUp(uint32_t i) const override
Time m_fragmentExpirationTimeout
Expiration timeout.
TracedCallback< const Ipv4Header &, Ptr< const Packet >, uint32_t > m_sendOutgoingTrace
Trace of sent packets.
EventId m_timeoutEvent
Event for the next scheduled timeout.
int32_t GetInterfaceForPrefix(Ipv4Address addr, Ipv4Mask mask) const override
Return the interface number of first interface found that has an Ipv4 address within the prefix speci...
void SetWeakEsModel(bool model) override
Set or unset the Weak Es Model.
Time m_purge
time between purging expired duplicate entries
void SetNode(Ptr< Node > node)
Set node associated with this stack.
void IpMulticastForward(Ptr< Ipv4MulticastRoute > mrtentry, Ptr< const Packet > p, const Ipv4Header &header)
Forward a multicast packet.
TracedCallback< Ptr< const Packet >, Ptr< Ipv4 >, uint32_t > m_rxTrace
Trace of received packets.
uint16_t GetMetric(uint32_t i) const override
FragmentsTimeoutsList_t m_timeoutEventList
Timeout "events" container.
TracedCallback< Ptr< const Packet >, Ptr< Ipv4 >, uint32_t > m_txTrace
Trace of transmitted packets.
Ptr< Socket > CreateRawSocket() override
Creates a raw socket.
bool ProcessFragment(Ptr< Packet > &packet, Ipv4Header &ipHeader, uint32_t iif)
Process a packet fragment.
static TypeId GetTypeId()
Get the type ID.
Ipv4RoutingProtocol::UnicastForwardCallback m_ucb
Unicast forward callback.
void HandleTimeout()
Handles a fragmented packet timeout.
Ipv4Address SourceAddressSelection(uint32_t interface, Ipv4Address dest) override
Choose the source address to use with destination address.
void NotifyNewAggregate() override
This function will notify other components connected to the node that a new stack member is now conne...
Ipv4InterfaceReverseContainer m_reverseInterfacesContainer
Container of NetDevice / Interface index associations.
uint32_t AddInterface(Ptr< NetDevice > device) override
EventId m_cleanDpd
event to cleanup expired duplicate entries
void SendWithHeader(Ptr< Packet > packet, Ipv4Header ipHeader, Ptr< Ipv4Route > route) override
bool IsForwarding(uint32_t i) const override
void Send(Ptr< Packet > packet, Ipv4Address source, Ipv4Address destination, uint8_t protocol, Ptr< Ipv4Route > route) override
Ptr< NetDevice > GetNetDevice(uint32_t i) override
L4List_t m_protocols
List of transport protocol.
uint32_t GetNAddresses(uint32_t interface) const override
void SetDown(uint32_t i) override
void SetRoutingProtocol(Ptr< Ipv4RoutingProtocol > routingProtocol) override
Register a new routing protocol to be used by this Ipv4 stack.
Ptr< Ipv4RoutingProtocol > GetRoutingProtocol() const override
Get the routing protocol to be used by this Ipv4 stack.
Ptr< Ipv4RoutingProtocol > m_routingProtocol
Routing protocol associated with the stack.
Ipv4RoutingProtocol::MulticastForwardCallback m_mcb
Multicast forward callback.
TracedCallback< const Ipv4Header &, Ptr< const Packet >, uint32_t > m_multicastForwardTrace
Trace of multicast forwarded packets.
uint8_t m_defaultTtl
Default TTL.
bool m_weakEsModel
Weak ES model state.
DupMap_t m_dups
map of packet duplicate tuples to expiry event
void SendRealOut(Ptr< Ipv4Route > route, Ptr< Packet > packet, const Ipv4Header &ipHeader)
Send packet with route.
Ptr< Node > m_node
Node attached to stack.
bool UpdateDuplicate(Ptr< const Packet > p, const Ipv4Header &header)
Registers duplicate entry, return false if new.
Ipv4Address SelectSourceAddress(Ptr< const NetDevice > device, Ipv4Address dst, Ipv4InterfaceAddress::InterfaceAddressScope_e scope) override
Return the first primary source address with scope less than or equal to the requested scope,...
bool RemoveAddress(uint32_t interfaceIndex, uint32_t addressIndex) override
Remove the address at addressIndex on named interface.
Ipv4InterfaceAddress GetAddress(uint32_t interfaceIndex, uint32_t addressIndex) const override
Because addresses can be removed, the addressIndex is not guaranteed to be static across calls to thi...
int32_t GetInterfaceForAddress(Ipv4Address addr) const override
Return the interface number of the interface that has been assigned the specified IP address.
Ptr< Ipv4Interface > GetInterface(uint32_t i) const
Get an interface.
void IpForward(Ptr< Ipv4Route > rtentry, Ptr< const Packet > p, const Ipv4Header &header)
Forward a packet.
void SetForwarding(uint32_t i, bool val) override
std::list< std::tuple< Time, FragmentKey_t, Ipv4Header, uint32_t > >::iterator FragmentsTimeoutsListI_t
Container Iterator for fragment timeouts..
void SetupLoopback()
Setup loopback interface.
void SetDefaultTtl(uint8_t ttl)
int32_t GetInterfaceForDevice(Ptr< const NetDevice > device) const override
Ipv4RoutingProtocol::LocalDeliverCallback m_lcb
Local delivery callback.
void Insert(Ptr< IpL4Protocol > protocol) override
TracedCallback< const Ipv4Header &, Ptr< const Packet >, DropReason, Ptr< Ipv4 >, uint32_t > m_dropTrace
Trace of dropped packets.
FragmentsTimeoutsListI_t SetTimeout(FragmentKey_t key, Ipv4Header ipHeader, uint32_t iif)
Set a new timeout "event" for a fragmented packet.
bool GetIpForward() const override
Get the IP forwarding state.
std::pair< int, int32_t > L4ListKey_t
Container of the IPv4 L4 keys: protocol number, interface index.
uint32_t AddIpv4Interface(Ptr< Ipv4Interface > interface)
Add an IPv4 interface to the stack.
a class to represent an Ipv4 address mask
static Ipv4Mask GetLoopback()
PacketType
Packet types are used as they are in Linux.
uint32_t AddDevice(Ptr< NetDevice > device)
Associate a NetDevice to this node.
uint32_t GetNDevices() const
Ptr< NetDevice > GetDevice(uint32_t index) const
Retrieve the index-th NetDevice associated to this node.
static bool ChecksumEnabled()
void RegisterProtocolHandler(ProtocolHandler handler, uint16_t protocolType, Ptr< NetDevice > device, bool promiscuous=false)
virtual void NotifyNewAggregate()
Notify all Objects aggregated to this one of a new Object being aggregated.
Ptr< T > GetObject() const
Get a pointer to the requested aggregated Object.
virtual void DoDispose()
Destructor implementation.
Smart pointer class similar to boost::intrusive_ptr.
static EventId Schedule(const Time &delay, FUNC f, Ts &&... args)
Schedule an event to expire after delay.
static Time Now()
Return the current simulation virtual time.
static uint8_t IpTos2Priority(uint8_t ipTos)
Return the priority corresponding to a given TOS value.
SocketErrno
Enumeration of the possible errors returned by a socket.
indicates whether the socket has IP_TOS set.
uint8_t GetTos() const
Get the tag's TOS.
This class implements a tag that carries the socket-specific TTL of a packet to the IP layer.
uint8_t GetTtl() const
Get the tag's TTL.
indicates whether the socket has a priority set.
void SetPriority(uint8_t priority)
Set the tag's priority.
Simulation virtual time values and global simulation resolution.
bool IsStrictlyPositive() const
Exactly equivalent to t > 0.
AttributeValue implementation for Time.
The Traffic Control layer aims at introducing an equivalent of the Linux Traffic Control infrastructu...
virtual void Receive(Ptr< NetDevice > device, Ptr< const Packet > p, uint16_t protocol, const Address &from, const Address &to, NetDevice::PacketType packetType)
Called by NetDevices, incoming packet.
a unique identifier for an interface.
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 > MakeBooleanAccessor(T1 a1)
Ptr< const AttributeChecker > MakeBooleanChecker()
ObjectPtrContainerValue ObjectVectorValue
ObjectVectorValue is an alias for ObjectPtrContainerValue.
Ptr< const AttributeAccessor > MakeObjectVectorAccessor(U T::*memberVariable)
MakeAccessorHelper implementation for ObjectVector.
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_FATAL_ERROR(msg)
Report a fatal error with a message and terminate.
uint32_t Hash32(const char *buffer, const std::size_t size)
Compute 32-bit hash of a byte buffer, using the default hash function.
#define NS_LOG_ERROR(msg)
Use NS_LOG to output a message of level LOG_ERROR.
#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.
Ptr< T > CreateObject(Args &&... args)
Create an object by type, with varying number of constructor parameters.
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system.
Time Seconds(double value)
Construct a Time in the indicated unit.
Time MilliSeconds(uint64_t value)
Construct a Time in the indicated unit.
Ptr< const TraceSourceAccessor > MakeTraceSourceAccessor(T a)
Create a TraceSourceAccessor which will control access to the underlying trace source.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
U * PeekPointer(const Ptr< U > &p)
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...
-ns3 Test suite for the ns3 wrapper script