A Discrete-Event Network Simulator
API
ns3::LteRlcUm Class Reference

LTE RLC Unacknowledged Mode (UM), see 3GPP TS 36.322. More...

#include "lte-rlc-um.h"

+ Inheritance diagram for ns3::LteRlcUm:
+ Collaboration diagram for ns3::LteRlcUm:

Public Member Functions

 LteRlcUm ()
 
virtual ~LteRlcUm ()
 
virtual void DoDispose ()
 Destructor implementation. More...
 
virtual void DoNotifyHarqDeliveryFailure ()
 
virtual void DoNotifyTxOpportunity (uint32_t bytes, uint8_t layer, uint8_t harqId)
 MAC SAP. More...
 
virtual void DoReceivePdu (Ptr< Packet > p)
 
virtual void DoTransmitPdcpPdu (Ptr< Packet > p)
 RLC SAP. More...
 
- Public Member Functions inherited from ns3::LteRlc
 LteRlc ()
 
virtual ~LteRlc ()
 
LteMacSapUserGetLteMacSapUser ()
 
LteRlcSapProviderGetLteRlcSapProvider ()
 
void SetLcId (uint8_t lcId)
 
void SetLteMacSapProvider (LteMacSapProvider *s)
 
void SetLteRlcSapUser (LteRlcSapUser *s)
 
void SetRnti (uint16_t rnti)
 
- Public Member Functions inherited from ns3::Object
 Object ()
 Constructor. More...
 
virtual ~Object ()
 Destructor. More...
 
void AggregateObject (Ptr< Object > other)
 Aggregate two Objects together. More...
 
void Dispose (void)
 Dispose of this Object. More...
 
AggregateIterator GetAggregateIterator (void) const
 Get an iterator to the Objects aggregated to this one. More...
 
virtual TypeId GetInstanceTypeId (void) const
 Implement the GetInstanceTypeId method defined in ObjectBase. More...
 
template<typename T >
Ptr< T > GetObject (void) const
 Get a pointer to the requested aggregated Object. More...
 
template<typename T >
Ptr< T > GetObject (TypeId tid) const
 Get a pointer to the requested aggregated Object by TypeId. More...
 
void Initialize (void)
 Invoke DoInitialize on all Objects aggregated to this one. More...
 
bool IsInitialized (void) const
 Check if the object has been initialized. More...
 
- Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter >
 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...
 
- Public Member Functions inherited from ns3::ObjectBase
virtual ~ObjectBase ()
 Virtual destructor. More...
 
void GetAttribute (std::string name, AttributeValue &value) const
 Get the value of an attribute, raising fatal errors if unsuccessful. More...
 
bool GetAttributeFailSafe (std::string name, AttributeValue &value) const
 Get the value of an attribute without raising erros. More...
 
void SetAttribute (std::string name, const AttributeValue &value)
 Set a single attribute, raising fatal errors if unsuccessful. More...
 
bool SetAttributeFailSafe (std::string name, const AttributeValue &value)
 Set a single attribute without raising errors. More...
 
bool TraceConnect (std::string name, std::string context, const CallbackBase &cb)
 Connect a TraceSource to a Callback with a context. More...
 
bool TraceConnectWithoutContext (std::string name, const CallbackBase &cb)
 Connect a TraceSource to a Callback without a context. More...
 
bool TraceDisconnect (std::string name, std::string context, const CallbackBase &cb)
 Disconnect from a TraceSource a Callback previously connected with a context. More...
 
bool TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb)
 Disconnect from a TraceSource a Callback previously connected without a context. More...
 

Static Public Member Functions

static TypeId GetTypeId (void)
 
- Static Public Member Functions inherited from ns3::LteRlc
static TypeId GetTypeId (void)
 
- Static Public Member Functions inherited from ns3::Object
static TypeId GetTypeId (void)
 Register this type. More...
 
- Static Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter >
static void Cleanup (void)
 Noop. More...
 
- Static Public Member Functions inherited from ns3::ObjectBase
static TypeId GetTypeId (void)
 Get the type ID. More...
 

Private Types

enum  ReassemblingState_t { NONE = 0, WAITING_S0_FULL = 1, WAITING_SI_SF = 2 }
 Reassembling state. More...
 

Private Member Functions

void DoReportBufferStatus ()
 
void ExpireRbsTimer (void)
 
void ExpireReorderingTimer (void)
 
bool IsInsideReorderingWindow (SequenceNumber10 seqNumber)
 
void ReassembleAndDeliver (Ptr< Packet > packet)
 
void ReassembleOutsideWindow (void)
 
void ReassembleSnInterval (SequenceNumber10 lowSeqNumber, SequenceNumber10 highSeqNumber)
 

Private Attributes

SequenceNumber10 m_expectedSeqNumber
 Expected Sequence Number. More...
 
Ptr< Packetm_keepS0
 
uint32_t m_maxTxBufferSize
 
EventId m_rbsTimer
 
std::vector< Ptr< Packet > > m_reasBuffer
 
ReassemblingState_t m_reassemblingState
 
EventId m_reorderingTimer
 Timers. More...
 
std::map< uint16_t, Ptr< Packet > > m_rxBuffer
 
std::list< Ptr< Packet > > m_sdusBuffer
 
SequenceNumber10 m_sequenceNumber
 State variables. More...
 
std::vector< Ptr< Packet > > m_txBuffer
 
uint32_t m_txBufferSize
 
SequenceNumber10 m_vrUh
 
SequenceNumber10 m_vrUr
 
SequenceNumber10 m_vrUx
 
uint16_t m_windowSize
 Constants. More...
 

Additional Inherited Members

- Public Types inherited from ns3::LteRlc
typedef void(* NotifyTxTracedCallback) (uint16_t rnti, uint8_t lcid, uint32_t bytes)
 TracedCallback signature for NotifyTxOpportunity events. More...
 
typedef void(* ReceiveTracedCallback) (uint16_t rnti, uint8_t lcid, uint32_t bytes, uint64_t delay)
 TracedCallback signature for. More...
 
- Protected Member Functions inherited from ns3::Object
 Object (const Object &o)
 Copy an Object. More...
 
virtual void DoInitialize (void)
 Initialize() implementation. More...
 
virtual void NotifyNewAggregate (void)
 Notify all Objects aggregated to this one of a new Object being aggregated. More...
 
- Protected Member Functions inherited from ns3::ObjectBase
void ConstructSelf (const AttributeConstructionList &attributes)
 Complete construction of ObjectBase; invoked by derived classes. More...
 
virtual void NotifyConstructionCompleted (void)
 Notifier called once the ObjectBase is fully constructed. More...
 
- Protected Attributes inherited from ns3::LteRlc
uint8_t m_lcid
 
LteMacSapProviderm_macSapProvider
 
LteMacSapUserm_macSapUser
 
LteRlcSapProviderm_rlcSapProvider
 
LteRlcSapUserm_rlcSapUser
 
uint16_t m_rnti
 
TracedCallback< uint16_t, uint8_t, uint32_t, uint64_t > m_rxPdu
 Used to inform of a PDU reception from the MAC SAP user. More...
 
TracedCallback< uint16_t, uint8_t, uint32_t > m_txPdu
 Used to inform of a PDU delivery to the MAC SAP provider. More...
 

Detailed Description

LTE RLC Unacknowledged Mode (UM), see 3GPP TS 36.322.

Config Paths

ns3::LteRlcUm is accessible through the following paths with Config::Set and Config::Connect:

  • "/NodeList/[i]/DeviceList/[i]/$ns3::LteNetDevice/$ns3::LteEnbNetDevice/LteEnbRrc/UeMap/[i]/DataRadioBearerMap/[i]/LteRlc/$ns3::LteRlcUm"
  • "/NodeList/[i]/DeviceList/[i]/$ns3::LteNetDevice/$ns3::LteEnbNetDevice/LteEnbRrc/UeMap/[i]/Srb0/LteRlc/$ns3::LteRlcUm"
  • "/NodeList/[i]/DeviceList/[i]/$ns3::LteNetDevice/$ns3::LteEnbNetDevice/LteEnbRrc/UeMap/[i]/Srb1/LteRlc/$ns3::LteRlcUm"
  • "/NodeList/[i]/DeviceList/[i]/$ns3::LteNetDevice/$ns3::LteUeNetDevice/LteUeRrc/DataRadioBearerMap/[i]/LteRlc/$ns3::LteRlcUm"
  • "/NodeList/[i]/DeviceList/[i]/$ns3::LteNetDevice/$ns3::LteUeNetDevice/LteUeRrc/Srb0/LteRlc/$ns3::LteRlcUm"
  • "/NodeList/[i]/DeviceList/[i]/$ns3::LteNetDevice/$ns3::LteUeNetDevice/LteUeRrc/Srb1/LteRlc/$ns3::LteRlcUm"
  • "/NodeList/[i]/DeviceList/[i]/$ns3::LteEnbNetDevice/LteEnbRrc/UeMap/[i]/DataRadioBearerMap/[i]/LteRlc/$ns3::LteRlcUm"
  • "/NodeList/[i]/DeviceList/[i]/$ns3::LteEnbNetDevice/LteEnbRrc/UeMap/[i]/Srb0/LteRlc/$ns3::LteRlcUm"
  • "/NodeList/[i]/DeviceList/[i]/$ns3::LteEnbNetDevice/LteEnbRrc/UeMap/[i]/Srb1/LteRlc/$ns3::LteRlcUm"
  • "/NodeList/[i]/DeviceList/[i]/$ns3::LteUeNetDevice/LteUeRrc/DataRadioBearerMap/[i]/LteRlc/$ns3::LteRlcUm"
  • "/NodeList/[i]/DeviceList/[i]/$ns3::LteUeNetDevice/LteUeRrc/Srb0/LteRlc/$ns3::LteRlcUm"
  • "/NodeList/[i]/DeviceList/[i]/$ns3::LteUeNetDevice/LteUeRrc/Srb1/LteRlc/$ns3::LteRlcUm"

Attributes

  • MaxTxBufferSize: Maximum Size of the Transmission Buffer (in Bytes)
    • Set with class: ns3::UintegerValue
    • Underlying type: uint32_t 0:4294967295
    • Initial value: 10240
    • Flags: construct write read

No TraceSources are defined for this type.

TraceSources defined in parent class ns3::LteRlc

Size of this type is 320 bytes (on a 64-bit architecture).

Definition at line 35 of file lte-rlc-um.h.

Member Enumeration Documentation

Reassembling state.

Enumerator
NONE 
WAITING_S0_FULL 
WAITING_SI_SF 

Definition at line 100 of file lte-rlc-um.h.

Constructor & Destructor Documentation

ns3::LteRlcUm::LteRlcUm ( )

Definition at line 35 of file lte-rlc-um.cc.

References m_reassemblingState, NS_LOG_FUNCTION, and WAITING_S0_FULL.

ns3::LteRlcUm::~LteRlcUm ( )
virtual

Definition at line 49 of file lte-rlc-um.cc.

References NS_LOG_FUNCTION.

Member Function Documentation

void ns3::LteRlcUm::DoDispose ( void  )
virtual

Destructor implementation.

This method is called by Dispose() or by the Object's destructor, whichever comes first.

Subclasses are expected to implement their real destruction code in an overriden version of this method and chain up to their parent's implementation once they are done. i.e, for simplicity, the destructor of every subclass should be empty and its content should be moved to the associated DoDispose() method.

It is safe to call GetObject() from within this method.

Reimplemented from ns3::LteRlc.

Definition at line 71 of file lte-rlc-um.cc.

References ns3::EventId::Cancel(), ns3::LteRlc::DoDispose(), m_rbsTimer, m_reorderingTimer, and NS_LOG_FUNCTION.

+ Here is the call graph for this function:

void ns3::LteRlcUm::DoNotifyHarqDeliveryFailure ( )
virtual

Implements ns3::LteRlc.

Definition at line 403 of file lte-rlc-um.cc.

References NS_LOG_FUNCTION.

void ns3::LteRlcUm::DoTransmitPdcpPdu ( Ptr< Packet p)
virtual
void ns3::LteRlcUm::ExpireRbsTimer ( void  )
private

Definition at line 1187 of file lte-rlc-um.cc.

References DoReportBufferStatus(), m_rbsTimer, m_txBuffer, ns3::MilliSeconds(), NS_LOG_LOGIC, and ns3::Simulator::Schedule().

Referenced by DoNotifyTxOpportunity().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

void ns3::LteRlcUm::ExpireReorderingTimer ( void  )
private

Definition at line 1148 of file lte-rlc-um.cc.

References ns3::SequenceNumber10::GetValue(), ns3::LteRlc::m_lcid, m_reorderingTimer, ns3::LteRlc::m_rnti, m_rxBuffer, m_vrUh, m_vrUr, m_vrUx, NS_LOG_FUNCTION, NS_LOG_LOGIC, ReassembleSnInterval(), and ns3::Simulator::Schedule().

Referenced by DoReceivePdu().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

TypeId ns3::LteRlcUm::GetTypeId ( void  )
static

Definition at line 55 of file lte-rlc-um.cc.

References m_maxTxBufferSize, ns3::MakeUintegerAccessor(), and ns3::TypeId::SetParent().

Referenced by ns3::LteUeRrc::ApplyRadioResourceConfigDedicated(), and ns3::LteEnbRrc::GetRlcType().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

bool ns3::LteRlcUm::IsInsideReorderingWindow ( SequenceNumber10  seqNumber)
private

Definition at line 571 of file lte-rlc-um.cc.

References m_vrUh, m_windowSize, NS_LOG_FUNCTION, NS_LOG_LOGIC, and ns3::SequenceNumber10::SetModulusBase().

Referenced by DoReceivePdu(), and ReassembleOutsideWindow().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

void ns3::LteRlcUm::ReassembleAndDeliver ( Ptr< Packet packet)
private

Deliver one or multiple PDUs

Deliver full PDUs

Keep S0

Discard SI or SN

Deliver zero, one or multiple PDUs

Discard SI or SN

Deliver zero, one or multiple PDUs

Keep S0

ERROR: Transition not possible

Deliver (Kept)S0 + SN

Deliver zero, one or multiple PDUs

Keep SI

Deliver (Kept)S0 + SN

Deliver zero, one or multiple PDUs

Keep S0

ERROR: Transition not possible

Deliver one or multiple PDUs

Deliver full PDUs

Keep S0

Discard SN

Deliver zero, one or multiple PDUs

Discard SI or SN

Deliver zero, one or multiple PDUs

Keep S0

ERROR: Transition not possible

Discard S0

Deliver one or multiple PDUs

Discard S0

Deliver zero, one or multiple PDUs

Keep S0

Discard S0

Discard SI or SN

Deliver zero, one or multiple PDUs

Discard S0

Discard SI or SN

Deliver zero, one or multiple PDUs

Keep S0

ERROR: Transition not possible

Definition at line 594 of file lte-rlc-um.cc.

References ns3::Packet::AddAtEnd(), ns3::Packet::CreateFragment(), ns3::LteRlcHeader::FIRST_BYTE, ns3::LteRlcHeader::GetFramingInfo(), ns3::LteRlcHeader::GetSequenceNumber(), ns3::Packet::GetSize(), ns3::LteRlcHeader::LAST_BYTE, m_expectedSeqNumber, m_keepS0, m_reassemblingState, ns3::LteRlc::m_rlcSapUser, m_sdusBuffer, ns3::LteRlcHeader::NO_FIRST_BYTE, ns3::LteRlcHeader::NO_LAST_BYTE, NS_LOG_LOGIC, ns3::LteRlcHeader::PopExtensionBit(), ns3::LteRlcHeader::PopLengthIndicator(), ns3::LteRlcSapUser::ReceivePdcpPdu(), ns3::Packet::RemoveAtStart(), ns3::Packet::RemoveHeader(), WAITING_S0_FULL, and WAITING_SI_SF.

Referenced by ReassembleOutsideWindow(), and ReassembleSnInterval().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

void ns3::LteRlcUm::ReassembleOutsideWindow ( void  )
private

Definition at line 1061 of file lte-rlc-um.cc.

References IsInsideReorderingWindow(), m_rxBuffer, NS_LOG_LOGIC, and ReassembleAndDeliver().

Referenced by DoReceivePdu().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

void ns3::LteRlcUm::ReassembleSnInterval ( SequenceNumber10  lowSeqNumber,
SequenceNumber10  highSeqNumber 
)
private

Definition at line 1087 of file lte-rlc-um.cc.

References ns3::SequenceNumber10::GetValue(), m_rxBuffer, NS_LOG_LOGIC, and ReassembleAndDeliver().

Referenced by DoReceivePdu(), and ExpireReorderingTimer().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

Member Data Documentation

SequenceNumber10 ns3::LteRlcUm::m_expectedSeqNumber
private

Expected Sequence Number.

Definition at line 109 of file lte-rlc-um.h.

Referenced by ReassembleAndDeliver().

Ptr<Packet> ns3::LteRlcUm::m_keepS0
private

Definition at line 104 of file lte-rlc-um.h.

Referenced by ReassembleAndDeliver().

uint32_t ns3::LteRlcUm::m_maxTxBufferSize
private

Definition at line 69 of file lte-rlc-um.h.

Referenced by DoTransmitPdcpPdu(), and GetTypeId().

EventId ns3::LteRlcUm::m_rbsTimer
private

Definition at line 95 of file lte-rlc-um.h.

Referenced by DoDispose(), DoNotifyTxOpportunity(), DoTransmitPdcpPdu(), and ExpireRbsTimer().

std::vector< Ptr<Packet> > ns3::LteRlcUm::m_reasBuffer
private

Definition at line 73 of file lte-rlc-um.h.

ReassemblingState_t ns3::LteRlcUm::m_reassemblingState
private

Definition at line 103 of file lte-rlc-um.h.

Referenced by LteRlcUm(), and ReassembleAndDeliver().

EventId ns3::LteRlcUm::m_reorderingTimer
private

Timers.

See section 7.3 in TS 36.322

Definition at line 94 of file lte-rlc-um.h.

Referenced by DoDispose(), DoReceivePdu(), and ExpireReorderingTimer().

std::map<uint16_t, Ptr<Packet> > ns3::LteRlcUm::m_rxBuffer
private
std::list< Ptr<Packet> > ns3::LteRlcUm::m_sdusBuffer
private

Definition at line 75 of file lte-rlc-um.h.

Referenced by ReassembleAndDeliver().

SequenceNumber10 ns3::LteRlcUm::m_sequenceNumber
private

State variables.

See section 7.1 in TS 36.322

Definition at line 80 of file lte-rlc-um.h.

Referenced by DoNotifyTxOpportunity().

std::vector< Ptr<Packet> > ns3::LteRlcUm::m_txBuffer
private
uint32_t ns3::LteRlcUm::m_txBufferSize
private

Definition at line 70 of file lte-rlc-um.h.

Referenced by DoNotifyTxOpportunity(), DoReportBufferStatus(), and DoTransmitPdcpPdu().

SequenceNumber10 ns3::LteRlcUm::m_vrUh
private

Definition at line 84 of file lte-rlc-um.h.

Referenced by DoReceivePdu(), ExpireReorderingTimer(), and IsInsideReorderingWindow().

SequenceNumber10 ns3::LteRlcUm::m_vrUr
private

Definition at line 82 of file lte-rlc-um.h.

Referenced by DoReceivePdu(), and ExpireReorderingTimer().

SequenceNumber10 ns3::LteRlcUm::m_vrUx
private

Definition at line 83 of file lte-rlc-um.h.

Referenced by DoReceivePdu(), and ExpireReorderingTimer().

uint16_t ns3::LteRlcUm::m_windowSize
private

Constants.

See section 7.2 in TS 36.322

Definition at line 89 of file lte-rlc-um.h.

Referenced by DoReceivePdu(), and IsInsideReorderingWindow().


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