A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
ns3::SixLowPanNetDevice::Fragments Class Reference

A Set of Fragment. More...

+ Inheritance diagram for ns3::SixLowPanNetDevice::Fragments:
+ Collaboration diagram for ns3::SixLowPanNetDevice::Fragments:

Public Member Functions

 Fragments ()
 Constructor. More...
 
 ~Fragments ()
 Destructor. More...
 
void AddFirstFragment (Ptr< Packet > fragment)
 Add the first packet fragment. More...
 
void AddFragment (Ptr< Packet > fragment, uint16_t fragmentOffset)
 Add a fragment to the pool. More...
 
std::list< Ptr< Packet > > GetFraments () const
 Get a list of the current stored fragments. More...
 
Ptr< PacketGetPacket () const
 Get the entire packet. More...
 
bool IsEntire () const
 If all fragments have been added. More...
 
void SetPacketSize (uint32_t packetSize)
 Set the packet-to-be-defragmented size. More...
 
- Public Member Functions inherited from ns3::SimpleRefCount< Fragments >
 SimpleRefCount ()
 Constructor. More...
 
 SimpleRefCount (const SimpleRefCount &o)
 Copy constructor. More...
 
uint32_t GetReferenceCount (void) const
 Get the reference count of the object. More...
 
SimpleRefCountoperator= (const SimpleRefCount &o)
 Assignment. More...
 
void Ref (void) const
 Increment the reference count. More...
 
void Unref (void) const
 Decrement the reference count. More...
 

Private Attributes

Ptr< Packetm_firstFragment
 The very first fragment. More...
 
std::list< std::pair< Ptr
< Packet >, uint16_t > > 
m_fragments
 The current fragments. More...
 
uint32_t m_packetSize
 The size of the reconstructed packet (bytes). More...
 

Additional Inherited Members

- Static Public Member Functions inherited from ns3::SimpleRefCount< Fragments >
static void Cleanup (void)
 Noop. More...
 

Detailed Description

A Set of Fragment.

Definition at line 321 of file sixlowpan-net-device.h.

Constructor & Destructor Documentation

ns3::SixLowPanNetDevice::Fragments::Fragments ( )

Constructor.

Definition at line 1923 of file sixlowpan-net-device.cc.

References m_packetSize, and NS_LOG_FUNCTION.

ns3::SixLowPanNetDevice::Fragments::~Fragments ( )

Destructor.

Definition at line 1929 of file sixlowpan-net-device.cc.

References NS_LOG_FUNCTION.

Member Function Documentation

void ns3::SixLowPanNetDevice::Fragments::AddFirstFragment ( Ptr< Packet fragment)

Add the first packet fragment.

The first fragment is needed to allow the post-defragmentation decompression.

Parameters
fragmentthe fragment

Definition at line 1960 of file sixlowpan-net-device.cc.

References NS_LOG_FUNCTION.

Referenced by ns3::SixLowPanNetDevice::ProcessFragment().

+ Here is the caller graph for this function:

void ns3::SixLowPanNetDevice::Fragments::AddFragment ( Ptr< Packet fragment,
uint16_t  fragmentOffset 
)

Add a fragment to the pool.

Parameters
fragmentthe fragment
fragmentOffsetthe offset of the fragment

Definition at line 1934 of file sixlowpan-net-device.cc.

References ns3::Packet::GetSize(), ns3::SixLowPanNetDevice::m_fragments, NS_ASSERT_MSG, and NS_LOG_FUNCTION.

Referenced by ns3::SixLowPanNetDevice::ProcessFragment().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

std::list< Ptr< Packet > > ns3::SixLowPanNetDevice::Fragments::GetFraments ( ) const

Get a list of the current stored fragments.

Definition at line 2035 of file sixlowpan-net-device.cc.

References ns3::SixLowPanNetDevice::m_fragments.

Ptr< Packet > ns3::SixLowPanNetDevice::Fragments::GetPacket ( ) const

Get the entire packet.

Returns
the entire packet

Definition at line 1999 of file sixlowpan-net-device.cc.

References ns3::Packet::AddAtEnd(), ns3::SixLowPanNetDevice::m_fragments, NS_ABORT_MSG, NS_LOG_FUNCTION, and NS_LOG_LOGIC.

Referenced by ns3::SixLowPanNetDevice::ProcessFragment().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

bool ns3::SixLowPanNetDevice::Fragments::IsEntire ( ) const

If all fragments have been added.

Returns
true if the packet is entire

Definition at line 1967 of file sixlowpan-net-device.cc.

References list, ns3::SixLowPanNetDevice::m_fragments, NS_LOG_FUNCTION, and NS_LOG_LOGIC.

Referenced by ns3::SixLowPanNetDevice::ProcessFragment().

+ Here is the caller graph for this function:

void ns3::SixLowPanNetDevice::Fragments::SetPacketSize ( uint32_t  packetSize)

Set the packet-to-be-defragmented size.

Parameters
packetSizethe packet size (bytes)

Definition at line 2029 of file sixlowpan-net-device.cc.

References NS_LOG_FUNCTION.

Referenced by ns3::SixLowPanNetDevice::ProcessFragment().

+ Here is the caller graph for this function:

Member Data Documentation

Ptr<Packet> ns3::SixLowPanNetDevice::Fragments::m_firstFragment
private

The very first fragment.

Definition at line 385 of file sixlowpan-net-device.h.

std::list<std::pair<Ptr<Packet>, uint16_t> > ns3::SixLowPanNetDevice::Fragments::m_fragments
private

The current fragments.

Definition at line 380 of file sixlowpan-net-device.h.

uint32_t ns3::SixLowPanNetDevice::Fragments::m_packetSize
private

The size of the reconstructed packet (bytes).

Definition at line 375 of file sixlowpan-net-device.h.

Referenced by Fragments().


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