23 #include "ns3/packet.h"
33 #include "ns3/ht-capabilities.h"
34 #include "ns3/vht-capabilities.h"
35 #include "ns3/he-capabilities.h"
53 .SetGroupName (
"Wifi")
130 uint32_t maxAmpduSize =
m_mac->GetMaxAmpduSize (ac);
132 if (maxAmpduSize == 0)
134 NS_LOG_DEBUG (
"A-MPDU Aggregation is disabled on this station for AC " << ac);
150 NS_ABORT_MSG_IF (!heCapabilities,
"HE Capabilities element not received");
152 maxAmpduSize =
std::min (maxAmpduSize, heCapabilities->GetMaxAmpduLength ());
156 NS_ABORT_MSG_IF (!vhtCapabilities,
"VHT Capabilities element not received");
158 maxAmpduSize =
std::min (maxAmpduSize, vhtCapabilities->GetMaxAmpduLength ());
162 NS_ABORT_MSG_IF (!htCapabilities,
"HT Capabilities element not received");
164 maxAmpduSize =
std::min (maxAmpduSize, htCapabilities->GetMaxAmpduLength ());
168 NS_LOG_DEBUG (
"A-MPDU aggregation is not available for non-HT PHYs");
179 return (4 - (ampduSize % 4 )) % 4;
194 std::vector<Ptr<WifiMacQueueItem>>
196 Time availableTime)
const
200 std::vector<Ptr<WifiMacQueueItem>> mpduList;
202 Mac48Address recipient = mpdu->GetHeader ().GetAddr1 ();
204 uint8_t tid = mpdu->GetHeader ().GetQosTid ();
216 while (nextMpdu != 0)
219 NS_LOG_DEBUG (
"Adding packet with sequence number " << nextMpdu->GetHeader ().GetSequenceNumber ()
220 <<
" to A-MPDU, packet size = " << nextMpdu->GetSize ()
221 <<
", A-MPDU size = " << txParams.
GetSize (recipient));
223 mpduList.push_back (nextMpdu);
227 peekedMpdu = qosTxop->
PeekNextMpdu (tid, recipient, nextMpdu);
241 nextMpdu = qosTxop->
GetNextMpdu (peekedMpdu, txParams, availableTime,
false);
245 if (mpduList.size () == 1)
bool IsBroadcast(void) const
Aggregator used to construct A-MPDUs.
static uint8_t CalculatePadding(uint32_t ampduSize)
void DoDispose() override
Destructor implementation.
Ptr< WifiMac > m_mac
the MAC of this station
static TypeId GetTypeId(void)
Get the type ID.
virtual ~MpduAggregator()
uint32_t GetMaxAmpduSize(Mac48Address recipient, uint8_t tid, WifiModulationClass modulation) const
Determine the maximum size for an A-MPDU of the given TID that can be sent to the given receiver when...
static void Aggregate(Ptr< const WifiMacQueueItem > mpdu, Ptr< Packet > ampdu, bool isSingle)
Aggregate an MPDU to an A-MPDU.
static AmpduSubframeHeader GetAmpduSubframeHeader(uint16_t mpduSize, bool isSingle)
Get the A-MPDU subframe header corresponding to the MPDU size and whether the MPDU is a single MPDU.
void SetWifiMac(const Ptr< WifiMac > mac)
Set the MAC layer to use.
std::vector< Ptr< WifiMacQueueItem > > GetNextAmpdu(Ptr< WifiMacQueueItem > mpdu, WifiTxParameters &txParams, Time availableTime) const
Attempt to aggregate other MPDUs to the given MPDU, while meeting the following constraints:
static uint32_t GetSizeIfAggregated(uint32_t mpduSize, uint32_t ampduSize)
Compute the size of the A-MPDU resulting from the aggregation of an MPDU of size mpduSize and an A-MP...
A base class which provides memory management and object aggregation.
virtual void DoDispose(void)
Destructor implementation.
void AddAtEnd(Ptr< const Packet > packet)
Concatenate the input packet at the end of the current packet.
void AddHeader(const Header &header)
Add header to this packet.
uint32_t GetSize(void) const
Returns the the size in bytes of the packet (including the zero-filled initial payload).
Smart pointer class similar to boost::intrusive_ptr.
uint16_t GetBaBufferSize(Mac48Address address, uint8_t tid) const
bool GetBaAgreementEstablished(Mac48Address address, uint8_t tid) const
Ptr< WifiMacQueueItem > GetNextMpdu(Ptr< const WifiMacQueueItem > peekedItem, WifiTxParameters &txParams, Time availableTime, bool initialFrame)
Prepare the frame to transmit starting from the MPDU that has been previously peeked by calling PeekN...
uint16_t GetBaStartingSequence(Mac48Address address, uint8_t tid) const
Ptr< const WifiMacQueueItem > PeekNextMpdu(uint8_t tid=8, Mac48Address recipient=Mac48Address::GetBroadcast(), Ptr< const WifiMacQueueItem > item=nullptr)
Peek the next frame to transmit to the given receiver and of the given TID from the EDCA queue.
Simulation virtual time values and global simulation resolution.
a unique identifier for an interface.
TypeId SetParent(TypeId tid)
Set the parent TypeId.
Ptr< const HtCapabilities > GetStationHtCapabilities(Mac48Address from)
Return the HT capabilities sent by the remote station.
Ptr< const HeCapabilities > GetStationHeCapabilities(Mac48Address from)
Return the HE capabilities sent by the remote station.
Ptr< const VhtCapabilities > GetStationVhtCapabilities(Mac48Address from)
Return the VHT capabilities sent by the remote station.
This class stores the TX parameters (TX vector, protection mechanism, acknowledgment mechanism,...
uint32_t GetSize(Mac48Address receiver) const
Get the size in bytes of the (A-)MPDU addressed to the given receiver.
WifiTxVector m_txVector
TXVECTOR of the frame being prepared.
WifiModulationClass GetModulationClass(void) 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_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(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
#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_MOD_CLASS_HT
HT (Clause 19)
@ 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.
void AddWifiMacTrailer(Ptr< Packet > packet)
Add FCS trailer to a packet.
bool IsInWindow(uint16_t seq, uint16_t winstart, uint16_t winsize)