21 #include "ns3/simulator.h"
24 #include "ns3/lte-rlc-header.h"
25 #include "ns3/lte-rlc-um.h"
26 #include "ns3/lte-rlc-sdu-status-tag.h"
27 #include "ns3/lte-rlc-tag.h"
36 : m_maxTxBufferSize (2 * 1024 * 1024),
43 m_expectedSeqNumber (0)
60 .AddConstructor<LteRlcUm> ()
61 .AddAttribute (
"MaxTxBufferSize",
62 "Maximum Size of the Transmission Buffer (in Bytes)",
65 MakeUintegerChecker<uint32_t> ())
133 uint32_t nextSegmentSize = bytes - 2;
134 uint32_t nextSegmentId = 1;
135 uint32_t dataFieldTotalSize = 0;
136 uint32_t dataFieldAddedSize = 0;
137 std::vector < Ptr<Packet> > dataField;
150 NS_LOG_LOGIC (
"Next segment size = " << nextSegmentSize);
157 while ( firstSegment && (firstSegment->
GetSize () > 0) && (nextSegmentSize > 0) )
159 NS_LOG_LOGIC (
"WHILE ( firstSegment && firstSegment->GetSize > 0 && nextSegmentSize > 0 )");
161 NS_LOG_LOGIC (
" nextSegmentSize = " << nextSegmentSize);
162 if ( (firstSegment->
GetSize () > nextSegmentSize) ||
164 (firstSegment->
GetSize () > 2047)
169 uint32_t currSegmentSize = std::min (firstSegment->
GetSize (), nextSegmentSize);
171 NS_LOG_LOGIC (
" IF ( firstSegment > nextSegmentSize ||");
199 if (firstSegment->
GetSize () > 0)
206 NS_LOG_LOGIC (
" TX buffer: Give back the remaining segment");
231 dataFieldAddedSize = newSegment->
GetSize ();
232 dataFieldTotalSize += dataFieldAddedSize;
233 dataField.push_back (newSegment);
241 nextSegmentSize -= dataFieldAddedSize;
249 else if ( (nextSegmentSize - firstSegment->
GetSize () <= 2) || (
m_txBuffer.size () == 0) )
251 NS_LOG_LOGIC (
" IF nextSegmentSize - firstSegment->GetSize () <= 2 || txBuffer.size == 0");
253 dataFieldAddedSize = firstSegment->
GetSize ();
254 dataFieldTotalSize += dataFieldAddedSize;
255 dataField.push_back (firstSegment);
263 nextSegmentSize -= dataFieldAddedSize;
272 NS_LOG_LOGIC (
" Next segment size = " << nextSegmentSize);
281 NS_LOG_LOGIC (
" IF firstSegment < NextSegmentSize && txBuffer.size > 0");
283 dataFieldAddedSize = firstSegment->
GetSize ();
284 dataFieldTotalSize += dataFieldAddedSize;
285 dataField.push_back (firstSegment);
291 rlcHeader.PushLengthIndicator (firstSegment->
GetSize ());
293 nextSegmentSize -= ((nextSegmentId % 2) ? (2) : (1)) + dataFieldAddedSize;
302 NS_LOG_LOGIC (
" Next segment size = " << nextSegmentSize);
318 std::vector< Ptr<Packet> >::iterator it;
319 it = dataField.begin ();
321 uint8_t framingInfo = 0;
325 (*it)->RemovePacketTag (tag);
335 (*it)->AddPacketTag (tag);
337 while (it < dataField.end ())
339 NS_LOG_LOGIC (
"Adding SDU/segment to packet, length = " << (*it)->GetSize ());
347 (*it)->RemovePacketTag (tag);
357 (*it)->AddPacketTag (tag);
359 rlcHeader.SetFramingInfo (framingInfo);
374 params.layer = layer;
479 NS_LOG_LOGIC (
"VR(UR) is outside the reordering window");
494 std::map <uint16_t, Ptr<Packet> >::iterator it;
499 newVrUr = (it->first) + 1;
575 NS_LOG_LOGIC (seqNumber <<
" is INSIDE the reordering window");
580 NS_LOG_LOGIC (seqNumber <<
" is OUTSIDE the reordering window");
597 expectedSnLost =
true;
603 expectedSnLost =
false;
609 uint8_t extensionBit;
610 uint16_t lengthIndicator;
616 if ( extensionBit == 0 )
626 if ( lengthIndicator >= packet->
GetSize () )
628 NS_LOG_LOGIC (
"INTERNAL ERROR: Not enough data in the packet (" << packet->
GetSize () <<
"). Needed LI=" << lengthIndicator);
638 while ( extensionBit == 1 );
640 std::list < Ptr<Packet> >::iterator it;
645 else NS_LOG_LOGIC (
"Reassembling State = Unknown state");
648 NS_LOG_LOGIC (
"Framing Info = " << (uint16_t)framingInfo);
746 NS_LOG_LOGIC (
"INTERNAL ERROR: Transition not possible. FI = " << (uint32_t) framingInfo);
817 NS_LOG_LOGIC (
"INTERNAL ERROR: Transition not possible. FI = " << (uint32_t) framingInfo);
922 NS_LOG_LOGIC (
"INTERNAL ERROR: Transition not possible. FI = " << (uint32_t) framingInfo);
1039 NS_LOG_LOGIC (
"INTERNAL ERROR: Transition not possible. FI = " << (uint32_t) framingInfo);
1058 std::map <uint16_t, Ptr<Packet> >::iterator it;
1068 std::map <uint16_t, Ptr<Packet> >::iterator it_tmp = it;
1075 NS_LOG_LOGIC (
"(SN = " << it->first <<
") is inside the reordering window");
1082 NS_LOG_LOGIC (
"Reassemble SN between " << lowSeqNumber <<
" and " << highSeqNumber);
1084 std::map <uint16_t, Ptr<Packet> >::iterator it;
1089 while (reassembleSn < highSeqNumber)
1114 uint32_t queueSize = 0;
1119 m_txBuffer.front ()->PeekPacketTag (holTimeTag);
1154 std::map <uint16_t, Ptr<Packet> >::iterator it;