21 #include "ns3/packet.h" 
   36     .SetGroupName (
"Internet")
 
   38     .AddTraceSource (
"NextRxSequence",
 
   39                      "Next sequence number expected (RCV.NXT)",
 
   41                      "ns3::SequenceNumber32TracedValueCallback")
 
   54   : m_nextRxSeq (n), m_gotFin (false), m_size (0), m_maxBuffer (32768), m_availBytes (0)
 
  144   uint32_t pktSize = p->
GetSize ();
 
  147   NS_LOG_LOGIC (
"Add pkt " << p << 
" len=" << pktSize << 
" seq=" << headSeq
 
  155       if (maxSeq < tailSeq) tailSeq = maxSeq;
 
  156       if (tailSeq < headSeq) headSeq = tailSeq;
 
  160   while (i != 
m_data.end () && i->first <= tailSeq)
 
  162       SequenceNumber32 lastByteSeq = i->first + 
SequenceNumber32 (i->second->GetSize ());
 
  163       if (lastByteSeq > headSeq)
 
  165           if (i->first > headSeq && lastByteSeq < tailSeq)
 
  167               m_size -= i->second->GetSize ();
 
  171           if (i->first <= headSeq)
 
  173               headSeq = lastByteSeq;
 
  175           if (lastByteSeq >= tailSeq)
 
  183   if (headSeq >= tailSeq)
 
  191       uint32_t length = 
static_cast<uint32_t
> (tailSeq - headSeq);
 
  208   for (i = m_data.begin (); i != m_data.end (); ++i)
 
  235   return static_cast<uint32_t
> (
m_sackList.size ());
 
  245   current.first = head;
 
  246   current.second = tail;
 
  278   bool updated = 
false;
 
  279   TcpOptionSack::SackList::iterator it = 
m_sackList.begin ();
 
  291       if (begin.first == current.second)
 
  293           NS_ASSERT (current.first < begin.second);
 
  299       else if (begin.second == current.first)
 
  301           NS_ASSERT (begin.first < current.second);
 
  340   TcpOptionSack::SackList::iterator it;
 
  346       if (block.second <= seq)
 
  369   NS_LOG_LOGIC (
"Requested to extract " << extractSize << 
" bytes from TcpRxBuffer of size=" << 
m_size);
 
  370   if (extractSize == 0) 
return nullptr;  
 
  379       uint32_t pktSize = i->second->GetSize ();
 
  380       if (pktSize <= extractSize)
 
  382           outPkt->AddAtEnd (i->second);
 
  386           extractSize -= pktSize;
 
  390           outPkt->AddAtEnd (i->second->CreateFragment (0, extractSize));
 
  391           m_data[i->first + 
SequenceNumber32 (extractSize)] = i->second->CreateFragment (extractSize, pktSize - extractSize);
 
  398   if (outPkt->GetSize () == 0)
 
  404                              << 
", num pkts in buffer=" << 
m_data.size ());
 
uint32_t m_availBytes
Number of bytes available to read, i.e. 
 
uint32_t m_maxBuffer
Upper bound of the number of data bytes in buffer (RCV.WND) 
 
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by "...
 
bool Add(Ptr< Packet > p, TcpHeader const &tcph)
Insert a packet into the buffer and update the availBytes counter to reflect the number of bytes read...
 
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system. 
 
TracedValue< SequenceNumber32 > m_nextRxSeq
Seqnum of the first missing byte in data (RCV.NXT) 
 
std::list< SackBlock > SackList
SACK list definition. 
 
uint32_t Available() const 
Get the actual number of bytes available to be read. 
 
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file...
 
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name. 
 
uint32_t GetSize(void) const 
Returns the the size in bytes of the packet (including the zero-filled initial payload). 
 
void SetFinSequence(const SequenceNumber32 &s)
Set the FIN Sequence number (i.e., the one closing the connection) 
 
void ClearSackList(const SequenceNumber32 &seq)
Remove old blocks from the sack list. 
 
SequenceNumber32 NextRxSequence(void) const 
Get Next Rx Sequence number. 
 
Ptr< const TraceSourceAccessor > MakeTraceSourceAccessor(T a)
Create a TraceSourceAccessor which will control access to the underlying trace source. 
 
SequenceNumber32 MaxRxSequence(void) const 
Get the lowest sequence number that this TcpRxBuffer cannot accept. 
 
Ptr< Packet > CreateFragment(uint32_t start, uint32_t length) const 
Create a new packet which contains a fragment of the original packet. 
 
TcpOptionSack::SackList GetSackList() const 
Get the sack list. 
 
uint32_t GetSackListSize() const 
Get the size of Sack list. 
 
void IncNextRxSequence(void)
Increment the Next Sequence number. 
 
bool m_gotFin
Did I received FIN packet? 
 
void UpdateSackList(const SequenceNumber32 &head, const SequenceNumber32 &tail)
Update the sack list, with the block seq starting at the beginning. 
 
Rx reordering buffer for TCP. 
 
void SetNextRxSequence(const SequenceNumber32 &s)
Set the Next Sequence number. 
 
void SetMaxBufferSize(uint32_t s)
Set the Maximum buffer size. 
 
TcpRxBuffer(uint32_t n=0)
Constructor. 
 
SequenceNumber32 m_finSeq
Seqnum of the FIN packet. 
 
Ptr< Packet > Extract(uint32_t maxSize)
Extract data from the head of the buffer as indicated by nextRxSeq. 
 
Every class exported by the ns3 library is enclosed in the ns3 namespace. 
 
std::map< SequenceNumber32, Ptr< Packet > > m_data
Corresponding data (may be null) 
 
NS_LOG_LOGIC("Net device "<< nd<< " is not bridged")
 
std::pair< SequenceNumber32, SequenceNumber32 > SackBlock
SACK block definition. 
 
uint32_t MaxBufferSize(void) const 
Get the Maximum buffer size. 
 
uint32_t m_size
Number of total data bytes in the buffer, not necessarily contiguous. 
 
TcpOptionSack::SackList m_sackList
Sack list (updated constantly) 
 
static TypeId GetTypeId(void)
Get the type ID. 
 
A base class which provides memory management and object aggregation. 
 
uint32_t Size(void) const 
Get the actual buffer occupancy. 
 
a unique identifier for an interface. 
 
TypeId SetParent(TypeId tid)
Set the parent TypeId. 
 
SequenceNumber< uint32_t, int32_t > SequenceNumber32
32 bit Sequence number. 
 
bool Finished(void)
Check if the buffer did receive all the data (and the connection is closed) 
 
std::map< SequenceNumber32, Ptr< Packet > >::iterator BufIterator
container for data stored in the buffer