25#include "ns3/arp-l3-protocol.h" 
   26#include "ns3/boolean.h" 
   27#include "ns3/config.h" 
   28#include "ns3/error-channel.h" 
   29#include "ns3/icmpv4-l4-protocol.h" 
   30#include "ns3/icmpv6-l4-protocol.h" 
   31#include "ns3/inet-socket-address.h" 
   32#include "ns3/inet6-socket-address.h" 
   33#include "ns3/internet-stack-helper.h" 
   34#include "ns3/ipv4-l3-protocol.h" 
   35#include "ns3/ipv4-list-routing.h" 
   36#include "ns3/ipv4-raw-socket-factory.h" 
   37#include "ns3/ipv4-static-routing.h" 
   38#include "ns3/ipv6-l3-protocol.h" 
   39#include "ns3/ipv6-list-routing.h" 
   40#include "ns3/ipv6-raw-socket-factory.h" 
   41#include "ns3/ipv6-static-routing.h" 
   44#include "ns3/simple-net-device.h" 
   45#include "ns3/simulator.h" 
   46#include "ns3/socket-factory.h" 
   47#include "ns3/socket.h" 
   49#include "ns3/traffic-control-layer.h" 
   50#include "ns3/udp-l4-protocol.h" 
   51#include "ns3/udp-socket-factory.h" 
   52#include "ns3/udp-socket.h" 
   53#include "ns3/uinteger.h" 
   56#include "ns3/win32-internet.h" 
   58#include <netinet/in.h> 
  109    void Print(std::ostream& os)
 const override 
  111        os << 
"token=" << 
token;
 
  153    void DoRun() 
override;
 
  232    : 
TestCase(
"Verify the IPv6 layer 3 protocol fragmentation and reassembly")
 
  272    while ((packet = socket->RecvFrom(from)))
 
  302    while ((packet = socket->RecvFrom(from)))
 
  328        m_data = 
new uint8_t[dataSize];
 
  332    if (fillSize >= dataSize)
 
  334        memcpy(
m_data, fill, dataSize);
 
  339    while (filled + fillSize < dataSize)
 
  341        memcpy(&
m_data[filled], fill, fillSize);
 
  345    memcpy(&
m_data[filled], fill, dataSize - filled);
 
  360        p = Create<Packet>(
m_size);
 
  364    p->AddPacketTag(tag);
 
  376                                ipv6->GetMtu(interface),
 
  377                                "Received packet size > MTU: packetSizes: " << packet->GetSize());
 
  385        ipv6->GetMtu(interface),
 
  386        "Transmitted packet size > MTU: packetSizes: " << packet->GetSize());
 
  395    internet.SetIpv4StackInstall(
false);
 
  398    Ptr<Node> serverNode = CreateObject<Node>();
 
  399    internet.Install(serverNode);
 
  403        serverDev = CreateObject<SimpleNetDevice>();
 
  405        serverDev->SetMtu(1500);
 
  406        serverDev->SetReceiveErrorModel(serverDevErrorModel);
 
  407        serverDevErrorModel->Disable();
 
  408        serverNode->AddDevice(serverDev);
 
  410        uint32_t netdev_idx = ipv6->AddInterface(serverDev);
 
  413        ipv6->AddAddress(netdev_idx, ipv6Addr);
 
  414        ipv6->SetUp(netdev_idx);
 
  415        ipv6->TraceConnectWithoutContext(
 
  422    Ptr<Node> clientNode = CreateObject<Node>();
 
  423    internet.Install(clientNode);
 
  427        clientDev = CreateObject<SimpleNetDevice>();
 
  429        clientDev->SetMtu(1500);
 
  430        clientDev->SetReceiveErrorModel(clientDevErrorModel);
 
  431        clientDevErrorModel->Disable();
 
  432        clientNode->AddDevice(clientDev);
 
  434        uint32_t netdev_idx = ipv6->AddInterface(clientDev);
 
  437        ipv6->AddAddress(netdev_idx, ipv6Addr);
 
  438        ipv6->SetUp(netdev_idx);
 
  439        ipv6->TraceConnectWithoutContext(
 
  447    serverDev->SetChannel(channel);
 
  448    clientDev->SetChannel(channel);
 
  449    channel->SetJumpingTime(
Seconds(0.5));
 
  452    uint32_t packetSizes[5] = {1500, 2000, 5000, 10000, 65000};
 
  455    uint8_t fillData[78];
 
  456    for (
uint32_t k = 48; k <= 125; k++)
 
  458        fillData[k - 48] = k;
 
  462    for (
int i = 0; i < 5; i++)
 
  475        uint8_t recvBuffer[65000];
 
  481                              "Packet size not correct: recvSize: " 
  482                                  << recvSize << 
" packetSizes[" << i << 
"]: " << packetSizes[i]);
 
  487                              "Packet content differs");
 
  493    channel->SetJumpingMode(
true);
 
  494    for (
int i = 0; i < 5; i++)
 
  507        uint8_t recvBuffer[65000];
 
  513                              "Packet size not correct: recvSize: " 
  514                                  << recvSize << 
" packetSizes[" << i << 
"]: " << packetSizes[i]);
 
  519                              "Packet content differs");
 
  521    channel->SetJumpingMode(
false);
 
  530    clientDevErrorModel->Disable();
 
  531    serverDevErrorModel->Enable();
 
  532    for (
int i = 1; i < 5; i++)
 
  539        serverDevErrorModel->Reset();
 
  556                              "Client did not receive ICMPv6::TIME_EXCEEDED " << 
int(
m_icmpType)
 
  562    clientDevErrorModel->Disable();
 
  563    serverDevErrorModel->Disable();
 
  564    for (
int i = 0; i < 5; i++)
 
  593                                  "ByteTag name not correct");
 
Tag used in IPv6 Fragmentation Test.
void Serialize(TagBuffer buffer) const override
static TypeId GetTypeId()
Get the type ID.
TypeId GetInstanceTypeId() const override
Get the most derived TypeId for this Object.
uint64_t GetToken() const
Get the token.
uint64_t token
Token carried by the tag.
void Print(std::ostream &os) const override
void Deserialize(TagBuffer buffer) override
uint32_t GetSerializedSize() const override
void SetToken(uint64_t token)
Set the token.
void HandleReadServer(Ptr< Socket > socket)
Handle incoming packets.
Ptr< Socket > m_socketClient
Client socket.
uint32_t m_dataSize
Data size.
void SetFill(uint8_t *fill, uint32_t fillSize, uint32_t dataSize)
Set the packet fill.
uint8_t m_icmpCode
ICMP code.
void HandleReadIcmpClient(Ipv6Address icmpSource, uint8_t icmpTtl, uint8_t icmpType, uint8_t icmpCode, uint32_t icmpInfo)
Handle incoming ICMP packets.
Ptr< Socket > m_socketServer
Server socket.
void DoRun() override
Implementation to actually run this TestCase.
void StartServer(Ptr< Node > ServerNode)
Start the server.
~Ipv6FragmentationTest() override
Ptr< Packet > m_receivedPacketServer
Packet received by server.
Ptr< Packet > m_sentPacketClient
Packet sent by client.
void HandleReadClient(Ptr< Socket > socket)
Handle incoming packets.
Ptr< Packet > SendClient()
Send a packet.
void HandleServerRx(Ptr< const Packet > packet, Ptr< Ipv6 > ipv6, uint32_t interface)
Handle Server's incoming packets.
void HandleClientTx(Ptr< const Packet > packet, Ptr< Ipv6 > ipv6, uint32_t interface)
Handle Client's transmitting packets.
uint8_t m_icmpType
ICMP type.
uint32_t m_size
packet size.
Ptr< Packet > m_receivedPacketClient
Packet received by client.
void StartClient(Ptr< Node > ClientNode)
Start the client.
IPv6 Fragmentation TestSuite.
Ipv6FragmentationTestSuite()
a polymophic address class
Identifies a byte tag and a set of bytes within a packet to which the tag applies.
uint32_t GetEnd() const
The index is an offset from the start of the packet.
void GetTag(Tag &tag) const
Read the requested tag and store it in the user-provided tag instance.
uint32_t GetStart() const
The index is an offset from the start of the packet.
Iterator over the set of byte tags in a packet.
AttributeValue implementation for Callback.
static bool IsMatchingType(const Address &addr)
If the address match.
aggregate IP/TCP/UDP functionality to existing Nodes.
Describes an IPv6 address.
static Ipv6Address GetAny()
Get the "any" (::) Ipv6Address.
Access to the IPv6 forwarding table, interfaces, and configuration.
IPv6 address associated with an interface.
Describes an IPv6 prefix.
static Mac48Address ConvertFrom(const Address &address)
static Mac48Address Allocate()
Allocate a new Mac48Address.
void SetAttribute(std::string name, const AttributeValue &value)
Set a single attribute, raising fatal errors if unsuccessful.
uint32_t GetSize() const
Returns the the size in bytes of the packet (including the zero-filled initial payload).
uint32_t CopyData(uint8_t *buffer, uint32_t size) const
Copy the packet contents to a byte buffer.
bool PeekPacketTag(Tag &tag) const
Search a matching tag and call Tag::Deserialize if it is found.
ByteTagIterator GetByteTagIterator() const
Returns an iterator over the set of byte tags included in this packet.
Smart pointer class similar to boost::intrusive_ptr.
static void Destroy()
Execute the events scheduled with ScheduleDestroy().
static void ScheduleWithContext(uint32_t context, const Time &delay, FUNC f, Ts &&... args)
Schedule an event with the given context.
static void Run()
Run the simulation.
virtual int Send(Ptr< Packet > p, uint32_t flags)=0
Send data (or dummy data) to the remote host.
virtual int Connect(const Address &address)=0
Initiate a connection to a remote host.
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 Bind(const Address &address)=0
Allocate a local endpoint for this socket.
virtual Ptr< Node > GetNode() const =0
Return the node this socket is associated with.
void WriteU64(uint64_t v)
tag a set of bytes in a packet
void AddTestCase(TestCase *testCase, TestDuration duration=QUICK)
Add an individual child TestCase to this test suite.
@ UNIT
This test suite implements a Unit Test.
a unique identifier for an interface.
static TypeId LookupByName(std::string name)
Get a TypeId by name.
Callback< ObjectBase * > GetConstructor() const
Get the constructor callback.
TypeId SetParent(TypeId tid)
Set the parent TypeId.
std::string GetName() const
Get the name.
A sockets interface to UDP.
#define NS_TEST_EXPECT_MSG_LT_OR_EQ(actual, limit, msg)
Test that an actual value is less than or equal to a limit and report if not.
#define NS_TEST_EXPECT_MSG_NE(actual, limit, msg)
Test that an actual and expected (limit) value are not equal and report if not.
#define NS_TEST_EXPECT_MSG_EQ(actual, limit, msg)
Test that an actual and expected (limit) value are equal and report if not.
Time Seconds(double value)
Construct a Time in the indicated unit.
static Ipv6FragmentationTestSuite g_ipv6fragmentationTestSuite
Static variable for test initialization.
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...
static const uint32_t packetSize
Packet size generated at the AP.