30 #include "ns3/ht-capabilities.h"
31 #include "ns3/ht-frame-exchange-manager.h"
33 #include "ns3/packet.h"
93 Time availableTime)
const
99 uint8_t tid = peekedItem->GetHeader().GetQosTid();
100 auto recipient = peekedItem->GetOriginal()->GetHeader().GetAddr1();
106 NS_ABORT_MSG_IF(recipient.IsBroadcast(),
"Recipient address is broadcast");
128 peekedItem = queue->PeekByTidAndAddress(tid, recipient, peekedItem->GetOriginal());
132 while (peekedItem && !peekedItem->GetHeader().IsQosAmsdu() &&
133 m_htFem->TryAggregateMsdu(peekedItem =
m_htFem->CreateAliasIfNeeded(peekedItem),
138 "Found item with sequence number assignment after one without: perhaps "
139 "sequence numbers were not released correctly?");
142 peekedItem = queue->PeekByTidAndAddress(tid, recipient, msdu);
143 queue->DequeueIfQueued({amsdu});
145 amsdu->Aggregate(msdu);
146 queue->Replace(msdu, amsdu);
153 NS_LOG_DEBUG(
"Aggregation failed (could not aggregate at least two MSDUs)");
158 return m_htFem->CreateAliasIfNeeded(amsdu);
164 return (4 - (amsduSize % 4)) % 4;
179 if (maxAmsduSize == 0)
181 NS_LOG_DEBUG(
"A-MSDU Aggregation is disabled on this station for AC " << ac);
189 auto ehtCapabilities = stationManager->GetStationEhtCapabilities(recipient);
190 auto vhtCapabilities = stationManager->GetStationVhtCapabilities(recipient);
191 auto htCapabilities = stationManager->GetStationHtCapabilities(recipient);
197 uint16_t maxMpduSize = 0;
200 maxMpduSize = ehtCapabilities->GetMaxMpduLength();
204 maxMpduSize = vhtCapabilities->GetMaxMpduLength();
213 NS_LOG_DEBUG(
"A-MSDU Aggregation disabled because the recipient did not"
214 " send an HT Capabilities element");
225 maxAmsduSize =
std::min(maxAmsduSize,
static_cast<uint16_t
>(maxMpduSize - 56));
236 maxAmsduSize =
std::min(maxAmsduSize, htCapabilities->GetMaxAmsduLength());
241 maxAmsduSize =
std::min(maxAmsduSize,
static_cast<uint16_t
>(maxMpduSize - 56));
250 maxAmsduSize =
std::min(maxAmsduSize,
static_cast<uint16_t
>(maxMpduSize - 56));
257 maxAmsduSize =
std::min(maxAmsduSize, htCapabilities->GetMaxAmsduLength());
263 maxAmsduSize =
std::min(maxAmsduSize,
static_cast<uint16_t
>(3839));
277 uint32_t maxSize = aggregatedPacket->
GetSize();
278 uint16_t extractedLength;
280 uint32_t deserialized = 0;
282 while (deserialized < maxSize)
286 extractedMsdu = aggregatedPacket->
CreateFragment(0,
static_cast<uint32_t
>(extractedLength));
288 deserialized += extractedLength;
290 padding = (4 - ((extractedLength + 14) % 4)) % 4;
292 if (padding > 0 && deserialized < maxSize)
295 deserialized += padding;
299 set.push_back(packetHdr);
301 NS_LOG_INFO(
"Deaggreated A-MSDU: extracted " << set.size() <<
" MSDUs");
Aggregator used to construct A-MSDUs.
static TypeId GetTypeId()
Get the type ID.
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...
void DoDispose() override
Destructor implementation.
Ptr< WifiMac > m_mac
the MAC of this station
uint8_t m_linkId
ID of the link this object is connected to.
static WifiMpdu::DeaggregatedMsdus Deaggregate(Ptr< Packet > aggregatedPacket)
Ptr< HtFrameExchangeManager > m_htFem
the HT Frame Exchange Manager of this station
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-MS...
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:
void SetWifiMac(const Ptr< WifiMac > mac)
Set the MAC layer to use.
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 a...
void SetLinkId(uint8_t linkId)
Set the ID of the link this MSDU aggregator is associated with.
A base class which provides memory management and object aggregation.
virtual void DoDispose()
Destructor implementation.
uint32_t RemoveHeader(Header &header)
Deserialize and remove the header from the internal buffer.
uint32_t GetSize() const
Returns the the size in bytes of the packet (including the zero-filled initial payload).
void RemoveAtStart(uint32_t size)
Remove size bytes from the start of the current packet.
Ptr< Packet > CreateFragment(uint32_t start, uint32_t length) const
Create a new packet which contains a fragment of the original packet.
Simulation virtual time values and global simulation resolution.
a unique identifier for an interface.
TypeId SetParent(TypeId tid)
Set the parent TypeId.
uint16_t GetMaxAmsduSize(AcIndex ac) const
Return the maximum A-MSDU size of the given Access Category.
Ptr< FrameExchangeManager > GetFrameExchangeManager(uint8_t linkId=SINGLE_LINK_OP_ID) const
Get the Frame Exchange Manager associated with the given link.
Ptr< WifiPhy > GetWifiPhy(uint8_t linkId=SINGLE_LINK_OP_ID) const
virtual Ptr< WifiMacQueue > GetTxopQueue(AcIndex ac) const
Get the wifi MAC queue of the (Qos)Txop associated with the given AC, if such (Qos)Txop is installed,...
Ptr< WifiRemoteStationManager > GetWifiRemoteStationManager(uint8_t linkId=0) const
std::list< std::pair< Ptr< const Packet >, AmsduSubframeHeader > > DeaggregatedMsdus
DeaggregatedMsdus typedef.
WifiPhyBand GetPhyBand() const
Get the configured Wi-Fi band.
WifiStandard GetStandard() const
Get the configured Wi-Fi standard.
This class stores the TX parameters (TX vector, protection mechanism, acknowledgment mechanism,...
WifiTxVector m_txVector
TXVECTOR of the frame being prepared.
WifiModulationClass GetModulationClass() const
Get the modulation class specified by this TXVECTOR.
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file,...
#define NS_ASSERT_MSG(condition, message)
At runtime, in debugging builds, if this condition is not true, the program prints the message to out...
#define NS_ABORT_MSG_IF(cond, msg)
Abnormal program termination if a condition is true, with a message.
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
#define NS_LOG_DEBUG(msg)
Use NS_LOG to output a message of level LOG_DEBUG.
#define NS_LOG_FUNCTION_NOARGS()
Output the name of the function.
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system.
AcIndex QosUtilsMapTidToAc(uint8_t tid)
Maps TID (Traffic ID) to Access classes.
WifiModulationClass
This enumeration defines the modulation classes per (Table 10-6 "Modulation classes"; IEEE 802....
AcIndex
This enumeration defines the Access Categories as an enumeration with values corresponding to the AC ...
@ WIFI_PHY_BAND_2_4GHZ
The 2.4 GHz band.
@ WIFI_MOD_CLASS_HT
HT (Clause 19)
@ WIFI_MOD_CLASS_EHT
EHT (Clause 36)
@ WIFI_MOD_CLASS_VHT
VHT (Clause 22)
@ WIFI_MOD_CLASS_HE
HE (Clause 27)
Every class exported by the ns3 library is enclosed in the ns3 namespace.