Aggregator used to construct A-MSDUs. More...
#include "msdu-aggregator.h"
Public Types | |
typedef std::map< AcIndex, Ptr< QosTxop > > | EdcaQueues |
EDCA queues typedef. More... | |
Public Member Functions | |
MsduAggregator ()=default | |
~MsduAggregator () override=default | |
uint16_t | GetMaxAmsduSize (Mac48Address recipient, uint8_t tid, WifiModulationClass modulation) const |
Determine the maximum size for an A-MSDU of the given TID that can be sent to the given receiver when using the given modulation class. More... | |
Ptr< WifiMpdu > | GetNextAmsdu (Ptr< WifiMpdu > peekedItem, WifiTxParameters &txParams, Time availableTime) const |
Attempt to aggregate other MSDUs to the given A-MSDU while meeting the following constraints: More... | |
void | SetLinkId (uint8_t linkId) |
Set the ID of the link this MSDU aggregator is associated with. More... | |
void | SetWifiMac (const Ptr< WifiMac > mac) |
Set the MAC layer to use. More... | |
Public Member Functions inherited from ns3::Object | |
Object () | |
Constructor. More... | |
~Object () override | |
Destructor. More... | |
void | AggregateObject (Ptr< Object > other) |
Aggregate two Objects together. More... | |
void | Dispose () |
Dispose of this Object. More... | |
AggregateIterator | GetAggregateIterator () const |
Get an iterator to the Objects aggregated to this one. More... | |
TypeId | GetInstanceTypeId () const override |
Get the most derived TypeId for this Object. More... | |
template<typename T > | |
Ptr< T > | GetObject () const |
Get a pointer to the requested aggregated Object. More... | |
template<> | |
Ptr< Object > | GetObject () const |
Specialization of () for objects of type ns3::Object. More... | |
template<typename T > | |
Ptr< T > | GetObject (TypeId tid) const |
Get a pointer to the requested aggregated Object by TypeId. More... | |
template<> | |
Ptr< Object > | GetObject (TypeId tid) const |
Specialization of (TypeId tid) for objects of type ns3::Object. More... | |
void | Initialize () |
Invoke DoInitialize on all Objects aggregated to this one. More... | |
bool | IsInitialized () const |
Check if the object has been initialized. More... | |
Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter > | |
SimpleRefCount () | |
Default constructor. More... | |
SimpleRefCount (const SimpleRefCount &o[[maybe_unused]]) | |
Copy constructor. More... | |
uint32_t | GetReferenceCount () const |
Get the reference count of the object. More... | |
SimpleRefCount & | operator= (const SimpleRefCount &o[[maybe_unused]]) |
Assignment operator. More... | |
void | Ref () const |
Increment the reference count. More... | |
void | Unref () 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 errors. 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 uint8_t | CalculatePadding (uint16_t amsduSize) |
Calculate how much padding must be added to the end of an A-MSDU of the given size if a new MSDU is added. More... | |
static WifiMpdu::DeaggregatedMsdus | Deaggregate (Ptr< Packet > aggregatedPacket) |
static uint16_t | GetSizeIfAggregated (uint16_t msduSize, uint16_t amsduSize) |
Compute the size of the A-MSDU resulting from the aggregation of an MSDU of size msduSize and an A-MSDU of size amsduSize. More... | |
static TypeId | GetTypeId () |
Get the type ID. More... | |
Static Public Member Functions inherited from ns3::Object | |
static TypeId | GetTypeId () |
Register this type. More... | |
Static Public Member Functions inherited from ns3::ObjectBase | |
static TypeId | GetTypeId () |
Get the type ID. More... | |
Protected Member Functions | |
void | DoDispose () override |
Destructor implementation. More... | |
Protected Member Functions inherited from ns3::Object | |
Object (const Object &o) | |
Copy an Object. More... | |
virtual void | DoInitialize () |
Initialize() implementation. More... | |
virtual void | NotifyNewAggregate () |
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 () |
Notifier called once the ObjectBase is fully constructed. More... | |
Private Attributes | |
Ptr< HtFrameExchangeManager > | m_htFem |
the HT Frame Exchange Manager of this station More... | |
uint8_t | m_linkId {0} |
ID of the link this object is connected to. More... | |
Ptr< WifiMac > | m_mac |
the MAC of this station More... | |
Additional Inherited Members | |
Related Functions inherited from ns3::ObjectBase | |
static TypeId | GetObjectIid () |
Ensure the TypeId for ObjectBase gets fully configured to anchor the inheritance tree properly. More... | |
Aggregator used to construct A-MSDUs.
Definition at line 46 of file msdu-aggregator.h.
typedef std::map<AcIndex, Ptr<QosTxop> > ns3::MsduAggregator::EdcaQueues |
EDCA queues typedef.
Definition at line 50 of file msdu-aggregator.h.
|
default |
|
overridedefault |
|
static |
Calculate how much padding must be added to the end of an A-MSDU of the given size if a new MSDU is added.
Each A-MSDU subframe is padded so that its length is multiple of 4 octets.
amsduSize | the size of the A-MSDU |
Definition at line 162 of file msdu-aggregator.cc.
Referenced by ns3::WifiMpdu::DoAggregate(), and GetSizeIfAggregated().
|
static |
aggregatedPacket | the aggregated packet. |
Definition at line 270 of file msdu-aggregator.cc.
References ns3::Packet::CreateFragment(), ns3::AmsduSubframeHeader::GetLength(), ns3::Packet::GetSize(), NS_LOG_FUNCTION_NOARGS, NS_LOG_INFO, ns3::Packet::RemoveAtStart(), and ns3::Packet::RemoveHeader().
Referenced by ns3::WifiMpdu::WifiMpdu().
|
overrideprotectedvirtual |
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 overridden 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::Object.
Definition at line 55 of file msdu-aggregator.cc.
References ns3::Object::DoDispose(), m_htFem, and m_mac.
uint16_t ns3::MsduAggregator::GetMaxAmsduSize | ( | Mac48Address | recipient, |
uint8_t | tid, | ||
WifiModulationClass | modulation | ||
) | const |
Determine the maximum size for an A-MSDU of the given TID that can be sent to the given receiver when using the given modulation class.
recipient | the receiver station address. |
tid | the TID. |
modulation | the modulation class. |
Definition at line 168 of file msdu-aggregator.cc.
References ns3::WifiMac::GetMaxAmsduSize(), ns3::WifiPhy::GetPhyBand(), ns3::WifiPhy::GetStandard(), ns3::WifiMac::GetWifiPhy(), ns3::WifiMac::GetWifiRemoteStationManager(), m_linkId, m_mac, min, NS_ABORT_MSG_IF, NS_ASSERT, NS_LOG_DEBUG, NS_LOG_FUNCTION, ns3::QosUtilsMapTidToAc(), ns3::WIFI_MOD_CLASS_EHT, ns3::WIFI_MOD_CLASS_HE, ns3::WIFI_MOD_CLASS_HT, ns3::WIFI_MOD_CLASS_VHT, ns3::WIFI_PHY_BAND_2_4GHZ, and ns3::WIFI_STANDARD_80211be.
Referenced by GetNextAmsdu().
Ptr< WifiMpdu > ns3::MsduAggregator::GetNextAmsdu | ( | Ptr< WifiMpdu > | peekedItem, |
WifiTxParameters & | txParams, | ||
Time | availableTime | ||
) | const |
Attempt to aggregate other MSDUs to the given A-MSDU while meeting the following constraints:
If aggregation succeeds (it was possible to aggregate at least an MSDU to the given MSDU), all the aggregated MSDUs are dequeued and an MPDU containing the A-MSDU is enqueued in the queue (replacing the given MPDU) and returned. Otherwise, no MSDU is dequeued from the EDCA queue and a null pointer is returned.
peekedItem | the MSDU which we attempt to aggregate other MSDUs to |
txParams | the TX parameters for the current frame |
availableTime | the time available for the frame exchange |
Definition at line 91 of file msdu-aggregator.cc.
References GetMaxAmsduSize(), ns3::WifiTxVector::GetModulationClass(), ns3::WifiMac::GetTxopQueue(), m_htFem, m_mac, ns3::WifiTxParameters::m_txVector, NS_ABORT_MSG_IF, NS_ASSERT, NS_ASSERT_MSG, NS_LOG_DEBUG, and NS_LOG_FUNCTION.
|
static |
Compute the size of the A-MSDU resulting from the aggregation of an MSDU of size msduSize and an A-MSDU of size amsduSize.
Note that only the basic A-MSDU subframe format (section 9.3.2.2.2 of IEEE 802.11-2016) is supported.
msduSize | the MSDU size in bytes. |
amsduSize | the A-MSDU size in bytes. |
Definition at line 82 of file msdu-aggregator.cc.
References CalculatePadding(), and NS_LOG_FUNCTION.
Referenced by ns3::WifiTxParameters::GetSizeIfAggregateMsdu().
|
static |
Get the type ID.
Definition at line 45 of file msdu-aggregator.cc.
References ns3::TypeId::SetParent().
void ns3::MsduAggregator::SetLinkId | ( | uint8_t | linkId | ) |
Set the ID of the link this MSDU aggregator is associated with.
linkId | the ID of the link this MSDU aggregator is associated with |
Definition at line 71 of file msdu-aggregator.cc.
References ns3::WifiMac::GetFrameExchangeManager(), m_htFem, m_linkId, m_mac, and NS_LOG_FUNCTION.
Set the MAC layer to use.
mac | the MAC layer to use |
Definition at line 63 of file msdu-aggregator.cc.
References ns3::WifiMac::GetFrameExchangeManager(), m_htFem, m_linkId, m_mac, third::mac, and NS_LOG_FUNCTION.
|
private |
the HT Frame Exchange Manager of this station
Definition at line 157 of file msdu-aggregator.h.
Referenced by DoDispose(), GetNextAmsdu(), SetLinkId(), and SetWifiMac().
|
private |
ID of the link this object is connected to.
Definition at line 158 of file msdu-aggregator.h.
Referenced by GetMaxAmsduSize(), SetLinkId(), and SetWifiMac().
the MAC of this station
Definition at line 156 of file msdu-aggregator.h.
Referenced by DoDispose(), GetMaxAmsduSize(), GetNextAmsdu(), SetLinkId(), and SetWifiMac().