32#include "ns3/eht-configuration.h"
33#include "ns3/eht-frame-exchange-manager.h"
34#include "ns3/he-configuration.h"
35#include "ns3/ht-configuration.h"
37#include "ns3/packet.h"
38#include "ns3/pointer.h"
39#include "ns3/vht-configuration.h"
51 : m_qosSupported(false)
74 "The ssid we want to belong to.",
78 .AddAttribute(
"QosSupported",
79 "This Boolean attribute is set to enable 802.11e/WMM-style QoS support "
86 .AddAttribute(
"CtsToSelfSupported",
87 "Use CTS to Self when using a rate that is not in the basic rate set.",
92 "ShortSlotTimeSupported",
93 "Whether or not short slot time is supported (only used by ERP APs or STAs).",
102 MakePointerChecker<Txop>())
103 .AddAttribute(
"VO_Txop",
104 "Queue that manages packets belonging to AC_VO access class.",
107 MakePointerChecker<QosTxop>())
108 .AddAttribute(
"VI_Txop",
109 "Queue that manages packets belonging to AC_VI access class.",
112 MakePointerChecker<QosTxop>())
113 .AddAttribute(
"BE_Txop",
114 "Queue that manages packets belonging to AC_BE access class.",
117 MakePointerChecker<QosTxop>())
118 .AddAttribute(
"BK_Txop",
119 "Queue that manages packets belonging to AC_BK access class.",
122 MakePointerChecker<QosTxop>())
123 .AddAttribute(
"VO_MaxAmsduSize",
124 "Maximum length in bytes of an A-MSDU for AC_VO access class "
125 "(capped to 7935 for HT PPDUs and 11398 for VHT/HE/EHT PPDUs). "
126 "Value 0 means A-MSDU aggregation is disabled for that AC.",
129 MakeUintegerChecker<uint16_t>(0, 11398))
130 .AddAttribute(
"VI_MaxAmsduSize",
131 "Maximum length in bytes of an A-MSDU for AC_VI access class "
132 "(capped to 7935 for HT PPDUs and 11398 for VHT/HE/EHT PPDUs). "
133 "Value 0 means A-MSDU aggregation is disabled for that AC.",
136 MakeUintegerChecker<uint16_t>(0, 11398))
137 .AddAttribute(
"BE_MaxAmsduSize",
138 "Maximum length in bytes of an A-MSDU for AC_BE access class "
139 "(capped to 7935 for HT PPDUs and 11398 for VHT/HE/EHT PPDUs). "
140 "Value 0 means A-MSDU aggregation is disabled for that AC.",
143 MakeUintegerChecker<uint16_t>(0, 11398))
144 .AddAttribute(
"BK_MaxAmsduSize",
145 "Maximum length in bytes of an A-MSDU for AC_BK access class "
146 "(capped to 7935 for HT PPDUs and 11398 for VHT/HE/EHT PPDUs). "
147 "Value 0 means A-MSDU aggregation is disabled for that AC.",
150 MakeUintegerChecker<uint16_t>(0, 11398))
153 "Maximum length in bytes of an A-MPDU for AC_VO access class "
154 "(capped to 65535 for HT PPDUs, 1048575 for VHT PPDUs, 6500631 for HE PPDUs "
155 "and 15523200 for EHT PPDUs). "
156 "Value 0 means A-MPDU aggregation is disabled for that AC.",
159 MakeUintegerChecker<uint32_t>(0, 15523200))
162 "Maximum length in bytes of an A-MPDU for AC_VI access class "
163 "(capped to 65535 for HT PPDUs, 1048575 for VHT PPDUs, 6500631 for HE PPDUs "
164 "and 15523200 for EHT PPDUs). "
165 "Value 0 means A-MPDU aggregation is disabled for that AC.",
168 MakeUintegerChecker<uint32_t>(0, 15523200))
171 "Maximum length in bytes of an A-MPDU for AC_BE access class "
172 "(capped to 65535 for HT PPDUs, 1048575 for VHT PPDUs, 6500631 for HE PPDUs "
173 "and 15523200 for EHT PPDUs). "
174 "Value 0 means A-MPDU aggregation is disabled for that AC.",
177 MakeUintegerChecker<uint32_t>(0, 15523200))
180 "Maximum length in bytes of an A-MPDU for AC_BK access class "
181 "(capped to 65535 for HT PPDUs, 1048575 for VHT PPDUs, 6500631 for HE PPDUs "
182 "and 15523200 for EHT PPDUs). "
183 "Value 0 means A-MPDU aggregation is disabled for that AC.",
186 MakeUintegerChecker<uint32_t>(0, 15523200))
188 "VO_BlockAckThreshold",
189 "If number of packets in VO queue reaches this value, "
190 "block ack mechanism is used. If this value is 0, block ack is never used."
191 "When A-MPDU is enabled, block ack mechanism is used regardless of this value.",
194 MakeUintegerChecker<uint8_t>(0, 64))
196 "VI_BlockAckThreshold",
197 "If number of packets in VI queue reaches this value, "
198 "block ack mechanism is used. If this value is 0, block ack is never used."
199 "When A-MPDU is enabled, block ack mechanism is used regardless of this value.",
202 MakeUintegerChecker<uint8_t>(0, 64))
204 "BE_BlockAckThreshold",
205 "If number of packets in BE queue reaches this value, "
206 "block ack mechanism is used. If this value is 0, block ack is never used."
207 "When A-MPDU is enabled, block ack mechanism is used regardless of this value.",
210 MakeUintegerChecker<uint8_t>(0, 64))
212 "BK_BlockAckThreshold",
213 "If number of packets in BK queue reaches this value, "
214 "block ack mechanism is used. If this value is 0, block ack is never used."
215 "When A-MPDU is enabled, block ack mechanism is used regardless of this value.",
218 MakeUintegerChecker<uint8_t>(0, 64))
220 "VO_BlockAckInactivityTimeout",
221 "Represents max time (blocks of 1024 microseconds) allowed for block ack"
222 "inactivity for AC_VO. If this value isn't equal to 0 a timer start after that a"
223 "block ack setup is completed and will be reset every time that a block ack"
224 "frame is received. If this value is 0, block ack inactivity timeout won't be "
228 MakeUintegerChecker<uint16_t>())
230 "VI_BlockAckInactivityTimeout",
231 "Represents max time (blocks of 1024 microseconds) allowed for block ack"
232 "inactivity for AC_VI. If this value isn't equal to 0 a timer start after that a"
233 "block ack setup is completed and will be reset every time that a block ack"
234 "frame is received. If this value is 0, block ack inactivity timeout won't be "
238 MakeUintegerChecker<uint16_t>())
240 "BE_BlockAckInactivityTimeout",
241 "Represents max time (blocks of 1024 microseconds) allowed for block ack"
242 "inactivity for AC_BE. If this value isn't equal to 0 a timer start after that a"
243 "block ack setup is completed and will be reset every time that a block ack"
244 "frame is received. If this value is 0, block ack inactivity timeout won't be "
248 MakeUintegerChecker<uint16_t>())
250 "BK_BlockAckInactivityTimeout",
251 "Represents max time (blocks of 1024 microseconds) allowed for block ack"
252 "inactivity for AC_BK. If this value isn't equal to 0 a timer start after that a"
253 "block ack setup is completed and will be reset every time that a block ack"
254 "frame is received. If this value is 0, block ack inactivity timeout won't be "
258 MakeUintegerChecker<uint16_t>())
259 .AddTraceSource(
"MacTx",
260 "A packet has been received from higher layers and is being processed "
261 "in preparation for "
262 "queueing for transmission.",
264 "ns3::Packet::TracedCallback")
267 "A packet has been dropped in the MAC layer before being queued for transmission. "
268 "This trace source is fired, e.g., when an AP's MAC receives from the upper layer "
269 "a packet destined to a station that is not associated with the AP or a STA's MAC "
270 "receives a packet from the upper layer while it is not associated with any AP.",
272 "ns3::Packet::TracedCallback")
275 "A packet has been received by this device, has been passed up from the physical "
277 "and is being forwarded up the local protocol stack. This is a promiscuous trace.",
279 "ns3::Packet::TracedCallback")
280 .AddTraceSource(
"MacRx",
281 "A packet has been received by this device, has been passed up from "
282 "the physical layer "
283 "and is being forwarded up the local protocol stack. This is a "
284 "non-promiscuous trace.",
286 "ns3::Packet::TracedCallback")
287 .AddTraceSource(
"MacRxDrop",
288 "A packet has been dropped in the MAC layer after it has been passed "
289 "up from the physical layer.",
291 "ns3::Packet::TracedCallback")
292 .AddTraceSource(
"TxOkHeader",
293 "The header of successfully transmitted packet.",
295 "ns3::WifiMacHeader::TracedCallback",
297 "Use the AckedMpdu trace instead.")
298 .AddTraceSource(
"TxErrHeader",
299 "The header of unsuccessfuly transmitted packet.",
301 "ns3::WifiMacHeader::TracedCallback",
303 "Depending on the failure type, use the NAckedMpdu trace, the "
304 "DroppedMpdu trace or one of the traces associated with TX timeouts.")
305 .AddTraceSource(
"AckedMpdu",
306 "An MPDU that was successfully acknowledged, via either a "
307 "Normal Ack or a Block Ack.",
309 "ns3::WifiMpdu::TracedCallback")
310 .AddTraceSource(
"NAckedMpdu",
311 "An MPDU that was negatively acknowledged via a Block Ack.",
313 "ns3::WifiMpdu::TracedCallback")
316 "An MPDU that was dropped for the given reason (see WifiMacDropReason).",
318 "ns3::WifiMac::DroppedMpduCallback")
320 "MpduResponseTimeout",
321 "An MPDU whose response was not received before the timeout, along with "
322 "an identifier of the type of timeout (see WifiTxTimer::Reason) and the "
323 "TXVECTOR used to transmit the MPDU. This trace source is fired when a "
324 "CTS is missing after an RTS, when all CTS frames are missing after an MU-RTS, "
325 "or when a Normal Ack is missing after an MPDU or after a DL MU PPDU "
326 "acknowledged in SU format.",
328 "ns3::WifiMac::MpduResponseTimeoutCallback")
330 "PsduResponseTimeout",
331 "A PSDU whose response was not received before the timeout, along with "
332 "an identifier of the type of timeout (see WifiTxTimer::Reason) and the "
333 "TXVECTOR used to transmit the PSDU. This trace source is fired when a "
334 "BlockAck is missing after an A-MPDU, a BlockAckReq (possibly in the "
335 "context of the acknowledgment of a DL MU PPDU in SU format) or a TB PPDU "
336 "(in the latter case the missing BlockAck is a Multi-STA BlockAck).",
338 "ns3::WifiMac::PsduResponseTimeoutCallback")
340 "PsduMapResponseTimeout",
341 "A PSDU map for which not all the responses were received before the timeout, "
342 "along with an identifier of the type of timeout (see WifiTxTimer::Reason), "
343 "the set of MAC addresses of the stations that did not respond and the total "
344 "number of stations that had to respond. This trace source is fired when not "
345 "all the addressed stations responded to an MU-BAR Trigger frame (either sent as "
346 "a SU frame or aggregated to PSDUs in the DL MU PPDU), a Basic Trigger Frame or "
347 "a BSRP Trigger Frame.",
349 "ns3::WifiMac::PsduMapResponseTimeoutCallback");
363 for (
auto it =
m_edca.begin(); it !=
m_edca.end(); ++it)
365 it->second->Initialize();
368 for (
const auto& [
id, link] :
m_links)
370 if (
auto cam = link->channelAccessManager)
392 for (
auto it =
m_edca.begin(); it !=
m_edca.end(); ++it)
395 it->second =
nullptr;
486 for (
auto& [
id, link] :
m_links)
488 link->feManager->SetPromisc();
508 const auto it = std::find_if(
m_edca.cbegin(),
m_edca.cend(), [ac](
const auto& pair) {
509 return pair.first == ac;
511 return (it ==
m_edca.cend() ?
nullptr : it->second);
548 return (txop ? txop->GetWifiMacQueue() :
nullptr);
558 for (
const auto& [aci, qosTxop] :
m_edca)
560 if (qosTxop->HasFramesToTransmit(linkId))
637 edca->GetBaManager()->SetTxOkCallback(
639 edca->GetBaManager()->SetTxFailedCallback(
641 edca->SetDroppedMpduCallback(
644 m_edca.insert(std::make_pair(ac, edca));
650 std::list<bool> isDsssOnly;
651 for (
const auto& [
id, link] :
m_links)
653 isDsssOnly.push_back(link->dsssSupported && !link->erpSupported);
664 for (
auto it =
m_edca.begin(); it !=
m_edca.end(); ++it)
666 ConfigureDcf(it->second, cwMin, cwMax, isDsssOnly, it->first);
674 std::list<bool> isDsss,
681 uint8_t aifsnValue = 0;
682 Time txopLimitDsss(0);
683 Time txopLimitNoDsss(0);
689 cwMinValue = (cwmin + 1) / 4 - 1;
690 cwMaxValue = (cwmin + 1) / 2 - 1;
696 cwMinValue = (cwmin + 1) / 2 - 1;
730 std::vector<uint32_t> cwValues(
m_links.size());
731 std::vector<uint8_t> aifsnValues(
m_links.size());
732 std::vector<Time> txopLimitValues(
m_links.size());
734 std::fill(cwValues.begin(), cwValues.end(), cwMinValue);
735 dcf->SetMinCws(cwValues);
736 std::fill(cwValues.begin(), cwValues.end(), cwMaxValue);
737 dcf->SetMaxCws(cwValues);
738 std::fill(aifsnValues.begin(), aifsnValues.end(), aifsnValue);
739 dcf->SetAifsns(aifsnValues);
740 std::transform(isDsss.begin(),
742 txopLimitValues.begin(),
743 [&txopLimitDsss, &txopLimitNoDsss](
bool dsss) {
744 return (dsss ? txopLimitDsss : txopLimitNoDsss);
746 dcf->SetTxopLimits(txopLimitValues);
756 for (
auto& [
id, link] :
m_links)
759 !link->phy || !link->phy->GetOperatingChannel().IsSet(),
761 <<
"] PHY must have been set and an operating channel must have been set");
765 if (!link->channelAccessManager)
767 link->channelAccessManager = CreateObject<ChannelAccessManager>();
769 link->channelAccessManager->SetupPhyListener(link->phy);
771 if (!link->feManager)
775 link->feManager->SetWifiPhy(link->phy);
776 link->feManager->SetWifiMac(
this);
777 link->feManager->SetLinkId(
id);
778 link->channelAccessManager->SetLinkId(
id);
779 link->channelAccessManager->SetupFrameExchangeManager(link->feManager);
784 link->channelAccessManager->Add(
m_txop);
786 for (
auto it =
m_edca.begin(); it !=
m_edca.end(); ++it)
788 it->second->SetWifiMac(
this);
789 link->channelAccessManager->Add(it->second);
823 feManager = CreateObject<EhtFrameExchangeManager>();
827 feManager = CreateObject<HeFrameExchangeManager>();
831 feManager = CreateObject<VhtFrameExchangeManager>();
835 feManager = CreateObject<HtFrameExchangeManager>();
839 feManager = CreateObject<QosFrameExchangeManager>();
843 feManager = CreateObject<FrameExchangeManager>();
849 feManager->GetWifiTxTimer().SetMpduResponseTimeoutCallback(
850 MakeCallback(&MpduResponseTimeoutTracedCallback::operator(),
852 feManager->GetWifiTxTimer().SetPsduResponseTimeoutCallback(
853 MakeCallback(&PsduResponseTimeoutTracedCallback::operator(),
855 feManager->GetWifiTxTimer().SetPsduMapResponseTimeoutCallback(
856 MakeCallback(&PsduMapResponseTimeoutTracedCallback::operator(),
858 feManager->SetDroppedMpduCallback(
860 feManager->SetAckedMpduCallback(
891 "If links have been already created, the number of provided "
892 "Remote Manager objects ("
893 << stationManagers.size()
895 "match the number of links ("
898 for (std::size_t i = 0; i < stationManagers.size(); i++)
903 it->second->stationManager = stationManagers[i];
913std::unique_ptr<WifiMac::LinkEntity>
916 return std::make_unique<LinkEntity>();
919const std::map<uint8_t, std::unique_ptr<WifiMac::LinkEntity>>&
928 auto it =
m_links.find(linkId);
940const std::set<uint8_t>&
954 link.feManager->SetLinkId(
id);
956 if (link.channelAccessManager)
958 link.channelAccessManager->SetLinkId(
id);
962std::optional<uint8_t>
965 for (
const auto& [
id, link] :
m_links)
967 if (link->feManager->GetAddress() == address)
975std::optional<uint8_t>
978 for (
const auto& [
id, link] :
m_links)
980 if (link->phy == phy)
988std::optional<uint8_t>
1001 std::map<uint8_t, uint8_t> actualPairs;
1003 while (!links.empty())
1005 auto from = links.cbegin()->first;
1006 auto to = links.cbegin()->second;
1011 links.erase(links.cbegin());
1015 std::unique_ptr<LinkEntity> linkToMove;
1017 linkToMove.swap(
m_links.at(from));
1022 auto [it, inserted] =
1025 actualPairs.emplace(from, to);
1037 auto nextTo = links.find(to);
1038 if (nextTo == links.cend())
1041 m_links[empty].swap(linkToMove);
1042 actualPairs.emplace(to, empty);
1047 to = nextTo->second;
1052 for (
const auto& [
id, link] :
m_links)
1061 for (
auto& [ac, edca] :
m_edca)
1063 edca->SwapLinks(actualPairs);
1075 "DL and UL directions for TID-to-Link mapping must be set separately");
1079 auto [it, inserted] = mappings.emplace(mldAddr, mapping);
1088 if (mapping.empty())
1095 for (
const auto& [tid, linkSet] : mapping)
1097 it->second[tid] = linkSet;
1101std::optional<std::reference_wrapper<const WifiTidLinkMapping>>
1105 "Cannot request TID-to-Link mapping for both directions");
1107 const auto& mappings =
1110 if (
const auto it = mappings.find(mldAddr); it != mappings.cend())
1114 return std::nullopt;
1121 "Cannot request TID-to-Link mapping for both directions");
1123 const auto& mappings =
1126 const auto it = mappings.find(mldAddr);
1128 if (it == mappings.cend())
1134 auto linkSetIt = it->second.find(tid);
1136 if (linkSetIt == it->second.cend())
1143 return std::find(linkSetIt->second.cbegin(), linkSetIt->second.cend(), linkId) !=
1144 linkSetIt->second.cend();
1154 "If links have been already created, the number of provided "
1157 <<
") must match the number "
1161 for (std::size_t i = 0; i < phys.size(); i++)
1168 it->second->phy = phys[i];
1182 for (
auto& [
id, link] :
m_links)
1184 if (link->feManager)
1186 link->feManager->ResetPhy();
1188 if (link->channelAccessManager)
1190 link->channelAccessManager->RemovePhyListener(link->phy);
1192 link->phy =
nullptr;
1206 m_txop = CreateObject<Txop>();
1313 "This method can be used to enforce TID-to-Link mapping for one direction at a time");
1315 const auto& mappings =
1318 auto it = mappings.find(mldAddr);
1320 if (it == mappings.cend())
1326 std::set<uint8_t> setupLinks;
1329 for (
const auto& [
id, link] :
m_links)
1331 if (link->stationManager->GetMldAddress(mldAddr))
1333 setupLinks.insert(
id);
1337 auto linkMapping = it->second;
1339 if (linkMapping.empty())
1342 for (uint8_t tid = 0; tid < 8; tid++)
1344 linkMapping.emplace(tid, setupLinks);
1348 for (
const auto& [tid, linkSet] : linkMapping)
1350 decltype(setupLinks) mappedLinks;
1351 auto notMappedLinks = setupLinks;
1353 for (
const auto id : linkSet)
1355 if (setupLinks.find(
id) != setupLinks.cend())
1358 mappedLinks.insert(
id);
1359 notMappedLinks.erase(
id);
1364 NS_ABORT_MSG_IF(mappedLinks.empty(),
"Every TID must be mapped to at least a link");
1375 if (!notMappedLinks.empty())
1391 const std::set<uint8_t>& linkIds)
1396 for (
const auto linkId : linkIds)
1399 auto linkAddr = link.stationManager->GetAffiliatedStaAddress(address).value_or(address);
1401 if (link.stationManager->GetMldAddress(address) == address && linkAddr == address)
1403 NS_LOG_DEBUG(
"Link " << +linkId <<
" has not been setup with the MLD, skip");
1415 {ac.GetLowTid(), ac.GetHighTid()},
1422 link.feManager->GetAddress(),
1432 const std::set<uint8_t>& linkIds)
1437 for (
const auto linkId : linkIds)
1440 auto linkAddr = link.stationManager->GetAffiliatedStaAddress(address).value_or(address);
1442 if (link.stationManager->GetMldAddress(address) == address && linkAddr == address)
1444 NS_LOG_DEBUG(
"Link " << +linkId <<
" has not been setup with the MLD, skip");
1456 {ac.GetLowTid(), ac.GetHighTid()},
1463 link.feManager->GetAddress(),
1471 qosTxop->HasFramesToTransmit(linkId))
1473 GetLink(linkId).channelAccessManager->RequestAccess(qosTxop);
1488 <<
") does not support Enqueue() with from address");
1503 const WifiMacHeader* hdr = &mpdu->GetOriginal()->GetHeader();
1535 packet->RemoveHeader(actionHdr);
1545 packet->RemoveHeader(reqHdr);
1551 auto htFem = DynamicCast<HtFrameExchangeManager>(link.feManager);
1554 htFem->SendAddBaResponse(&reqHdr, from);
1561 packet->RemoveHeader(respHdr);
1569 auto recipientMld = link.stationManager->GetMldAddress(from);
1570 auto recipient = (recipientMld ? *recipientMld : from);
1572 auto htFem = DynamicCast<HtFrameExchangeManager>(link.feManager);
1577 ->SetBlockAckInactivityCallback(
1585 packet->RemoveHeader(delBaHdr);
1586 auto recipientMld = link.stationManager->GetMldAddress(from);
1587 auto recipient = (recipientMld ? *recipientMld : from);
1597 ->DestroyRecipientAgreement(recipient, delBaHdr.
GetTid());
1610 NS_FATAL_ERROR(
"Unsupported Action field in Block Ack Action frame");
1628 msduPair.second.GetSourceAddr(),
1629 msduPair.second.GetDestinationAddr());
1633std::optional<Mac48Address>
1636 for (
const auto& [
id, link] :
m_links)
1638 if (
auto mldAddress = link->stationManager->GetMldAddress(remoteAddr))
1643 return std::nullopt;
1649 for (
const auto& [
id, link] :
m_links)
1651 if (
auto mldAddress = link->stationManager->GetMldAddress(remoteAddr))
1654 if (mldAddress != remoteAddr)
1657 return link->feManager->GetAddress();
1687 if (!agreement || !agreement->get().IsEstablished())
1689 return std::nullopt;
1698 originator =
GetMldAddress(originator).value_or(originator);
1707 "No existing Block Ack agreement with " << recipient <<
" TID: " << +tid);
1708 return agreement->get().GetBlockAckType();
1716 "No existing Block Ack agreement with " << recipient <<
" TID: " << +tid);
1717 return agreement->get().GetBlockAckReqType();
1725 "No existing Block Ack agreement with " << originator <<
" TID: " << +tid);
1726 return agreement->get().GetBlockAckType();
1734 "No existing Block Ack agreement with " << originator <<
" TID: " << +tid);
1735 return agreement->get().GetBlockAckReqType();
1790 for (
const auto& [
id, link] :
m_links)
1792 if (link->stationManager->GetHtSupported(address))
1803 for (
const auto& [
id, link] :
m_links)
1805 if (link->stationManager->GetVhtSupported(address))
1816 for (
const auto& [
id, link] :
m_links)
1818 if (link->stationManager->GetHeSupported(address))
1829 for (
const auto& [
id, link] :
m_links)
1831 if (link->stationManager->GetEhtSupported(address))
1927 return capabilities;
1939 bool sgiSupported = htConfiguration->GetShortGuardIntervalSupported();
1940 capabilities.
SetLdpc(htConfiguration->GetLdpcSupported());
1945 uint16_t maxAmsduSize =
1947 if (maxAmsduSize <= 3839)
1958 maxAmpduLength = (1UL <<
static_cast<uint32_t>(std::ceil(std::log2(maxAmpduLength + 1)))) - 1;
1960 capabilities.
SetMaxAmpduLength(std::min(std::max(maxAmpduLength, 8191U), 65535U));
1963 uint64_t maxSupportedRate = 0;
1967 uint8_t nss = (mcs.GetMcsValue() / 8) + 1;
1969 uint64_t dataRate = mcs.GetDataRate(phy->GetChannelWidth(), sgiSupported ? 400 : 800, nss);
1970 if (dataRate > maxSupportedRate)
1972 maxSupportedRate = dataRate;
1973 NS_LOG_DEBUG(
"Updating maxSupportedRate to " << maxSupportedRate);
1977 static_cast<uint16_t
>(maxSupportedRate / 1e6));
1984 return capabilities;
1997 "VHT stations have to support 40 MHz operation");
1999 bool sgiSupported = htConfiguration->GetShortGuardIntervalSupported();
2003 uint16_t maxAmsduSize =
2005 if (maxAmsduSize <= 3839)
2009 else if (maxAmsduSize <= 7935)
2020 maxAmpduLength = (1UL <<
static_cast<uint32_t>(std::ceil(std::log2(maxAmpduLength + 1)))) - 1;
2022 capabilities.
SetMaxAmpduLength(std::min(std::max(maxAmpduLength, 8191U), 1048575U));
2024 capabilities.
SetRxLdpc(htConfiguration->GetLdpcSupported());
2030 if (mcs.GetMcsValue() > maxMcs)
2032 maxMcs = mcs.GetMcsValue();
2036 for (uint8_t nss = 1; nss <= phy->GetMaxSupportedRxSpatialStreams(); nss++)
2040 for (uint8_t nss = 1; nss <= phy->GetMaxSupportedTxSpatialStreams(); nss++)
2044 uint64_t maxSupportedRateLGI = 0;
2047 if (!mcs.IsAllowed(phy->GetChannelWidth(), 1))
2051 if (mcs.GetDataRate(phy->GetChannelWidth()) > maxSupportedRateLGI)
2053 maxSupportedRateLGI = mcs.GetDataRate(phy->GetChannelWidth());
2054 NS_LOG_DEBUG(
"Updating maxSupportedRateLGI to " << maxSupportedRateLGI);
2058 static_cast<uint16_t
>(maxSupportedRateLGI / 1e6));
2060 static_cast<uint16_t
>(maxSupportedRateLGI / 1e6));
2065 return capabilities;
2078 uint8_t channelWidthSet = 0;
2081 channelWidthSet |= 0x01;
2086 channelWidthSet |= 0x02;
2088 if ((phy->GetChannelWidth() >= 160) &&
2091 channelWidthSet |= 0x04;
2095 if (heConfiguration->GetGuardInterval() ==
NanoSeconds(800))
2106 maxAmpduLength = (1UL <<
static_cast<uint32_t>(std::ceil(std::log2(maxAmpduLength + 1)))) - 1;
2108 capabilities.
SetMaxAmpduLength(std::min(std::max(maxAmpduLength, 1048575U), 8388607U));
2113 if (mcs.GetMcsValue() > maxMcs)
2115 maxMcs = mcs.GetMcsValue();
2121 return capabilities;
2136 uint16_t maxAmsduSize =
2139 if (maxAmsduSize <= 3839)
2143 else if (maxAmsduSize <= 7935)
2157 maxAmpduLength = (1UL <<
static_cast<uint32_t>(std::ceil(std::log2(maxAmpduLength + 1)))) - 1;
2159 capabilities.
SetMaxAmpduLength(std::min(std::max(maxAmpduLength, 8388607U), 16777215U));
2164 support4096Qam ? 1 : 0;
2166 support4096Qam ? 1 : 0;
2168 const uint8_t maxTxNss = phy->GetMaxSupportedTxSpatialStreams();
2169 const uint8_t maxRxNss = phy->GetMaxSupportedRxSpatialStreams();
2170 if (phy->GetChannelWidth() == 20)
2172 for (
auto maxMcs : {7, 9, 11, 13})
2186 for (
auto maxMcs : {9, 11, 13})
2198 if (phy->GetChannelWidth() >= 160)
2200 for (
auto maxMcs : {9, 11, 13})
2214 return capabilities;
2245 uint16_t maxSize = 0;
AttributeValue implementation for Boolean.
The IEEE 802.11be EHT Capabilities.
void SetMaxMpduLength(uint16_t length)
Set the maximum MPDU length.
void SetSupportedTxEhtMcsAndNss(EhtMcsAndNssSet::EhtMcsMapType mapType, uint8_t upperMcs, uint8_t maxNss)
Set a subfield of the Supported EHT-MCS And NSS Set.
EhtPhyCapabilities m_phyCapabilities
EHT PHY Capabilities Info subfield.
void SetMaxAmpduLength(uint32_t maxAmpduLength)
Set the maximum A-MPDU length.
void SetSupportedRxEhtMcsAndNss(EhtMcsAndNssSet::EhtMcsMapType mapType, uint8_t upperMcs, uint8_t maxNss)
Set a subfield of the Supported EHT-MCS And NSS Set.
The Extended Capabilities Information Element.
void SetHtSupported(uint8_t htSupported)
Set the HT Supported flag.
void SetVhtSupported(uint8_t vhtSupported)
Set the VHT Supported flag.
The IEEE 802.11ax HE Capabilities.
void SetHeSuPpdu1xHeLtf800nsGi(bool heSuPpdu1xHeLtf800nsGi)
Set 1xHE-LTF and 800ns GI in HE SU PPDU reception support.
void SetLdpcCodingInPayload(uint8_t ldpcCodingInPayload)
Set indication whether the transmission and reception of LDPC encoded packets is supported.
void SetHePpdu4xHeLtf800nsGi(bool heSuPpdu4xHeLtf800nsGi)
Set 4xHE-LTF and 800ns GI in HE SU PPDU and HE MU PPDU reception support.
void SetHighestNssSupported(uint8_t nss)
Set highest NSS supported.
void SetMaxAmpduLength(uint32_t maxAmpduLength)
Set the maximum AMPDU length.
void SetChannelWidthSet(uint8_t channelWidthSet)
Set channel width set.
void SetHighestMcsSupported(uint8_t mcs)
Set highest MCS supported.
The HT Capabilities Information Element.
void SetLdpc(uint8_t ldpc)
Set the LDPC field.
void SetTxRxMcsSetUnequal(uint8_t txRxMcsSetUnequal)
Set the transmit / receive MCS set unequal.
void SetRxHighestSupportedDataRate(uint16_t maxSupportedRate)
Set the receive highest supported data rate.
void SetLSigProtectionSupport(uint8_t lSigProtection)
Set the LSIG protection support.
void SetMaxAmsduLength(uint16_t maxAmsduLength)
Set the maximum AMSDU length.
void SetTxMaxNSpatialStreams(uint8_t maxTxSpatialStreams)
Set the transmit maximum N spatial streams.
void SetShortGuardInterval20(uint8_t shortGuardInterval)
Set the short guard interval 20 field.
void SetTxUnequalModulation(uint8_t txUnequalModulation)
Set the transmit unequal modulation.
void SetTxMcsSetDefined(uint8_t txMcsSetDefined)
Set the transmit MCS set defined.
void SetRxMcsBitmask(uint8_t index)
Set the receive MCS bitmask.
void SetSupportedChannelWidth(uint8_t supportedChannelWidth)
Set the supported channel width field.
void SetMaxAmpduLength(uint32_t maxAmpduLength)
Set the maximum AMPDU length.
void SetShortGuardInterval40(uint8_t shortGuardInterval)
Set the short guard interval 40 field.
void SendDelbaFrame(Mac48Address addr, uint8_t tid, bool byOriginator)
Sends DELBA frame to cancel a block ack agreement with STA addressed by addr for TID tid.
static Mac48Address ConvertFrom(const Address &address)
A base class which provides memory management and object aggregation.
void Initialize()
Invoke DoInitialize on all Objects aggregated to this one.
void Dispose()
Dispose of this Object.
bool IsInitialized() const
Check if the object has been initialized.
Hold objects of type Ptr<T>.
Smart pointer class similar to boost::intrusive_ptr.
Ptr< BlockAckManager > GetBaManager()
Get the Block Ack Manager associated with this QosTxop.
void GotAddBaResponse(const MgtAddBaResponseHeader &respHdr, Mac48Address recipient)
Event handler when an ADDBA response is received.
void SetBlockAckThreshold(uint8_t threshold)
Set threshold for block ack mechanism.
void GotDelBaFrame(const MgtDelBaHeader *delBaHdr, Mac48Address recipient)
Event handler when a DELBA frame is received.
void SetBlockAckInactivityTimeout(uint16_t timeout)
Set the BlockAck inactivity timeout.
static EventId ScheduleNow(FUNC f, Ts &&... args)
Schedule an event to expire Now.
The IEEE 802.11 SSID Information Element.
AttributeValue implementation for Ssid.
Simulation virtual time values and global simulation resolution.
virtual bool HasFramesToTransmit(uint8_t linkId)
Check if the Txop has frames to transmit over the given link.
virtual void SetWifiMac(const Ptr< WifiMac > mac)
Set the wifi MAC this Txop is associated to.
void SwapLinks(std::map< uint8_t, uint8_t > links)
Swap the links based on the information included in the given map.
void SetTxMiddle(const Ptr< MacTxMiddle > txMiddle)
Set MacTxMiddle this Txop is associated to.
virtual void SetDroppedMpduCallback(DroppedMpdu callback)
a unique identifier for an interface.
@ ATTR_GET
The attribute can be read.
@ ATTR_CONSTRUCT
The attribute can be written at construction-time.
TypeId SetParent(TypeId tid)
Set the parent TypeId.
@ OBSOLETE
Attribute or trace source is not used anymore; simulation fails.
Hold an unsigned integer type.
The IEEE 802.11ac VHT Capabilities.
void SetRxHighestSupportedLgiDataRate(uint16_t supportedDatarate)
Set the receive highest supported LGI data rate.
void SetSupportedChannelWidthSet(uint8_t channelWidthSet)
Set the supported channel width set.
void SetMaxMpduLength(uint16_t length)
Set the maximum MPDU length.
void SetRxLdpc(uint8_t rxLdpc)
Set the receive LDPC.
void SetTxStbc(uint8_t txStbc)
Set the transmit STBC.
void SetTxMcsMap(uint8_t mcs, uint8_t nss)
void SetShortGuardIntervalFor80Mhz(uint8_t shortGuardInterval)
Set the short guard interval 80 MHz.
void SetTxHighestSupportedLgiDataRate(uint16_t supportedDatarate)
Set the transmit highest supported LGI data rate.
void SetShortGuardIntervalFor160Mhz(uint8_t shortGuardInterval)
Set the short guard interval 160 MHz.
void SetMaxAmpduLength(uint32_t maxAmpduLength)
Set the maximum AMPDU length.
void SetRxMcsMap(uint8_t mcs, uint8_t nss)
void SetRxStbc(uint8_t rxStbc)
Set the receive STBC.
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< QosTxop > GetBEQueue() const
Accessor for the AC_BE channel access function.
virtual void NotifyChannelSwitching(uint8_t linkId)
Notify that channel on the given link has been switched.
std::optional< Mac48Address > GetMldAddress(const Mac48Address &remoteAddr) const
virtual void SetMacQueueScheduler(Ptr< WifiMacQueueScheduler > scheduler)
Set the wifi MAC queue scheduler.
Mac48Address GetBssid(uint8_t linkId) const
uint16_t m_viMaxAmsduSize
maximum A-MSDU size for AC_VI (in bytes)
bool m_shortSlotTimeSupported
flag whether short slot time is supported
void ConfigurePhyDependentParameters(uint8_t linkId)
Configure PHY dependent parameters such as CWmin and CWmax on the given link.
Ptr< HeConfiguration > GetHeConfiguration() const
DroppedMpduTracedCallback m_droppedMpduCallback
This trace indicates that an MPDU was dropped for the given reason.
TypeOfStation GetTypeOfStation() const
Return the type of station.
bool m_qosSupported
This Boolean is set true iff this WifiMac is to model 802.11e/WMM style Quality of Service.
const std::map< uint8_t, std::unique_ptr< LinkEntity > > & GetLinks() const
Ptr< Txop > GetTxop() const
Accessor for the Txop object.
VhtCapabilities GetVhtCapabilities(uint8_t linkId) const
Return the VHT capabilities of the device for the given link.
Callback< void > m_linkDown
Callback when a link is down.
bool GetQosSupported() const
Return whether the device supports QoS.
std::optional< std::reference_wrapper< const RecipientBlockAckAgreement > > RecipientAgreementOptConstRef
optional const reference to RecipientBlockAckAgreement
virtual void SetAddress(Mac48Address address)
Ptr< Txop > m_txop
TXOP used for transmission of frames to non-QoS peers.
void SetQosSupported(bool enable)
Enable or disable QoS support for the device.
Mac48Address m_address
MAC address of this station.
std::set< uint8_t > m_linkIds
IDs of the links in use.
Ptr< WifiMacQueueScheduler > GetMacQueueScheduler() const
Get the wifi MAC queue scheduler.
uint8_t GetNLinks() const
Get the number of links (can be greater than 1 for 11be devices only).
BlockAckType GetBaTypeAsRecipient(Mac48Address originator, uint8_t tid) const
void SwapLinks(std::map< uint8_t, uint8_t > links)
Swap the links based on the information included in the given map.
uint16_t m_voMaxAmsduSize
maximum A-MSDU size for AC_VO (in bytes)
Ptr< MacRxMiddle > m_rxMiddle
RX middle (defragmentation etc.)
Ptr< WifiMacQueueScheduler > m_scheduler
wifi MAC queue scheduler
void DoInitialize() override
Initialize() implementation.
TypeOfStation m_typeOfStation
the type of station
uint32_t m_beMaxAmpduSize
maximum A-MPDU size for AC_BE (in bytes)
virtual void ConfigureStandard(WifiStandard standard)
bool TidMappedOnLink(Mac48Address mldAddr, WifiDirection dir, uint8_t tid, uint8_t linkId) const
Check whether the given TID is mapped on the given link in the given direction for the given MLD.
void UnblockUnicastTxOnLinks(WifiQueueBlockedReason reason, const Mac48Address &address, const std::set< uint8_t > &linkIds)
Unblock the transmission on the given links of all unicast frames addressed to the station with the g...
void SetWifiRemoteStationManagers(const std::vector< Ptr< WifiRemoteStationManager > > &stationManagers)
void SetBeBlockAckThreshold(uint8_t threshold)
Set the block ack threshold for AC_BE.
bool GetErpSupported(uint8_t linkId) const
Return whether the device supports ERP on the given link.
bool GetHtSupported() const
Return whether the device supports HT.
void ResetWifiPhys()
Remove currently attached WifiPhy objects from this MAC.
TracedCallback< Ptr< const Packet > > m_macTxTrace
The trace source fired when packets come into the "top" of the device at the L3/L2 transition,...
void SetErpSupported(bool enable, uint8_t linkId)
Enable or disable ERP support for the given link.
uint32_t m_voMaxAmpduSize
maximum A-MPDU size for AC_VO (in bytes)
void ConfigureDcf(Ptr< Txop > dcf, uint32_t cwmin, uint32_t cwmax, std::list< bool > isDsss, AcIndex ac)
Ptr< WifiNetDevice > m_device
Pointer to the device.
void UpdateLinkId(uint8_t id)
This method is intended to be called when a link changes ID in order to update the link ID stored by ...
Ptr< QosTxop > GetVOQueue() const
Accessor for the AC_VO channel access function.
void SetTypeOfStation(TypeOfStation type)
This method is invoked by a subclass to specify what type of station it is implementing.
MpduTracedCallback m_ackedMpduCallback
ack'ed MPDU callback
Ptr< WifiPhy > GetWifiPhy(uint8_t linkId=SINGLE_LINK_OP_ID) const
void BlockUnicastTxOnLinks(WifiQueueBlockedReason reason, const Mac48Address &address, const std::set< uint8_t > &linkIds)
Block the transmission on the given links of all unicast frames addressed to the station with the giv...
MpduTracedCallback m_nackedMpduCallback
nack'ed MPDU callback
bool GetEhtSupported() const
Return whether the device supports EHT.
bool GetHeSupported() const
Return whether the device supports HE.
HtCapabilities GetHtCapabilities(uint8_t linkId) const
Return the HT capabilities of the device for the given link.
void SetBkBlockAckThreshold(uint8_t threshold)
Set the block ack threshold for AC_BK.
void SetVoBlockAckThreshold(uint8_t threshold)
Set the block ack threshold for AC_VO.
virtual std::optional< uint8_t > GetLinkIdByAddress(const Mac48Address &address) const
Get the ID of the link having the given MAC address, if any.
void NotifyPromiscRx(Ptr< const Packet > packet)
std::unordered_map< Mac48Address, WifiTidLinkMapping, WifiAddressHash > m_dlTidLinkMappings
DL TID-to-Link Mapping negotiated with an MLD (identified by its MLD address)
virtual bool HasFramesToTransmit(uint8_t linkId)
Check if the MAC has frames to transmit over the given link.
void SetWifiRemoteStationManager(Ptr< WifiRemoteStationManager > stationManager)
void ApplyTidLinkMapping(const Mac48Address &mldAddr, WifiDirection dir)
Apply the TID-to-Link Mapping negotiated with the given MLD for the given direction by properly confi...
RecipientAgreementOptConstRef GetBaAgreementEstablishedAsRecipient(Mac48Address originator, uint8_t tid) const
void SetBeBlockAckInactivityTimeout(uint16_t timeout)
Set BE block ack inactivity timeout.
Ptr< EhtConfiguration > GetEhtConfiguration() const
TracedCallback< Ptr< const Packet > > m_macRxTrace
The trace source fired for packets successfully received by the device immediately before being forwa...
bool GetVhtSupported(uint8_t linkId) const
Return whether the device supports VHT on the given link.
void SetDsssSupported(bool enable, uint8_t linkId)
Enable or disable DSSS support for the given link.
TracedCallback< Ptr< const Packet > > m_macTxDropTrace
The trace source fired when packets coming into the "top" of the device are dropped at the MAC layer ...
Ptr< MacTxMiddle > m_txMiddle
TX middle (aggregation etc.)
void NotifyTx(Ptr< const Packet > packet)
static TypeId GetTypeId()
Get the type ID.
Ptr< HtConfiguration > GetHtConfiguration() const
std::optional< std::reference_wrapper< const WifiTidLinkMapping > > GetTidToLinkMapping(Mac48Address mldAddr, WifiDirection dir) const
Get the TID-to-Link Mapping negotiated with the given MLD (if any) for the given direction.
uint32_t GetMaxAmpduSize(AcIndex ac) const
Return the maximum A-MPDU size of the given Access Category.
BlockAckReqType GetBarTypeAsRecipient(Mac48Address originator, uint8_t tid) const
Ssid m_ssid
Service Set ID (SSID)
std::map< uint8_t, std::unique_ptr< LinkEntity > > m_links
ID-indexed map of Link objects.
virtual void DeaggregateAmsduAndForward(Ptr< const WifiMpdu > mpdu)
This method can be called to de-aggregate an A-MSDU and forward the constituent packets up the stack.
Ptr< QosTxop > GetVIQueue() const
Accessor for the AC_VI channel access function.
void SetBssid(Mac48Address bssid, uint8_t linkId)
Ptr< WifiNetDevice > GetDevice() const
Return the device this PHY is associated with.
Ptr< FrameExchangeManager > SetupFrameExchangeManager(WifiStandard standard)
Create a Frame Exchange Manager depending on the supported version of the standard.
virtual void Enqueue(Ptr< Packet > packet, Mac48Address to, Mac48Address from)
void NotifyRx(Ptr< const Packet > packet)
TracedCallback< Ptr< const Packet > > m_macRxDropTrace
The trace source fired when packets coming into the "top" of the device are dropped at the MAC layer ...
void UpdateTidToLinkMapping(const Mac48Address &mldAddr, WifiDirection dir, const WifiTidLinkMapping &mapping)
Update the TID-to-Link Mappings for the given MLD in the given direction based on the given negotiate...
BlockAckType GetBaTypeAsOriginator(const Mac48Address &recipient, uint8_t tid) const
MpduResponseTimeoutTracedCallback m_mpduResponseTimeoutCallback
MPDU response timeout traced callback.
void SetForwardUpCallback(ForwardUpCallback upCallback)
PsduMapResponseTimeoutTracedCallback m_psduMapResponseTimeoutCallback
PSDU map response timeout traced callback.
ExtendedCapabilities GetExtendedCapabilities() const
Return the extended capabilities of the device.
TracedCallback< Ptr< const Packet > > m_macPromiscRxTrace
The trace source fired for packets successfully received by the device immediately before being forwa...
uint16_t m_bkMaxAmsduSize
maximum A-MSDU size for AC_BK (in bytes)
void SetBkBlockAckInactivityTimeout(uint16_t timeout)
Set BK block ack inactivity timeout.
std::optional< std::reference_wrapper< const OriginatorBlockAckAgreement > > OriginatorAgreementOptConstRef
optional const reference to OriginatorBlockAckAgreement
std::unordered_map< Mac48Address, WifiTidLinkMapping, WifiAddressHash > m_ulTidLinkMappings
UL TID-to-Link Mapping negotiated with an MLD (identified by its MLD address)
virtual bool SupportsSendFrom() 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,...
std::optional< uint8_t > GetLinkForPhy(Ptr< const WifiPhy > phy) const
Get the ID of the link (if any) on which the given PHY is operating.
void SetViBlockAckThreshold(uint8_t threshold)
Set the block ack threshold for AC_VI.
void SetViBlockAckInactivityTimeout(uint16_t timeout)
Set VI block ack inactivity timeout.
bool GetShortSlotTimeSupported() const
BlockAckReqType GetBarTypeAsOriginator(const Mac48Address &recipient, uint8_t tid) const
void SetupEdcaQueue(AcIndex ac)
This method is a private utility invoked to configure the channel access function for the specified A...
void SetLinkDownCallback(Callback< void > linkDown)
Ptr< QosTxop > GetBKQueue() const
Accessor for the AC_BK channel access function.
void SetPromisc()
Sets the interface in promiscuous mode.
Ptr< VhtConfiguration > GetVhtConfiguration() const
void NotifyRxDrop(Ptr< const Packet > packet)
virtual void SetLinkUpCallback(Callback< void > linkUp)
Ptr< WifiRemoteStationManager > GetWifiRemoteStationManager(uint8_t linkId=0) const
const std::set< uint8_t > & GetLinkIds() const
void SetDevice(const Ptr< WifiNetDevice > device)
Sets the device this PHY is associated with.
void SetCtsToSelfSupported(bool enable)
Enable or disable CTS-to-self feature.
Mac48Address GetLocalAddress(const Mac48Address &remoteAddr) const
Get the local MAC address used to communicate with a remote STA.
EdcaQueues m_edca
This is a map from Access Category index to the corresponding channel access function.
uint32_t m_bkMaxAmpduSize
maximum A-MPDU size for AC_BK (in bytes)
void ForwardUp(Ptr< const Packet > packet, Mac48Address from, Mac48Address to)
Forward the packet up to the device.
virtual void ConfigureContentionWindow(uint32_t cwMin, uint32_t cwMax)
OriginatorAgreementOptConstRef GetBaAgreementEstablishedAsOriginator(Mac48Address recipient, uint8_t tid) const
virtual void Receive(Ptr< const WifiMpdu > mpdu, uint8_t linkId)
This method acts as the MacRxMiddle receive callback and is invoked to notify us that a frame has bee...
Mac48Address GetAddress() const
TracedCallback< const WifiMacHeader & > m_txErrCallback
transmit error callback
ForwardUpCallback m_forwardUp
Callback to forward packet up the stack.
EhtCapabilities GetEhtCapabilities(uint8_t linkId) const
Return the EHT capabilities of the device for the given link.
Callback< void > m_linkUp
Callback when a link is up.
TracedCallback< const WifiMacHeader & > m_txOkCallback
transmit OK callback
LinkEntity & GetLink(uint8_t linkId) const
Get a reference to the link associated with the given ID.
HeCapabilities GetHeCapabilities(uint8_t linkId) const
Return the HE capabilities of the device for the given link.
virtual void SetWifiPhys(const std::vector< Ptr< WifiPhy > > &phys)
PsduResponseTimeoutTracedCallback m_psduResponseTimeoutCallback
PSDU response timeout traced callback.
Ptr< QosTxop > GetQosTxop(AcIndex ac) const
Accessor for a specified EDCA object.
void NotifyTxDrop(Ptr< const Packet > packet)
void DoDispose() override
Destructor implementation.
bool GetDsssSupported(uint8_t linkId) const
Return whether the device supports DSSS on the given link.
Ptr< ChannelAccessManager > GetChannelAccessManager(uint8_t linkId=SINGLE_LINK_OP_ID) const
Get the Channel Access Manager associated with the given link.
void SetVoBlockAckInactivityTimeout(uint16_t timeout)
Set VO block ack inactivity timeout.
virtual std::unique_ptr< LinkEntity > CreateLinkEntity() const
Create a LinkEntity object.
void SetShortSlotTimeSupported(bool enable)
Enable or disable short slot time feature.
bool m_ctsToSelfSupported
flag indicating whether CTS-To-Self is supported
uint16_t m_beMaxAmsduSize
maximum A-MSDU size for AC_BE (in bytes)
virtual Mac48Address DoGetLocalAddress(const Mac48Address &remoteAddr) const
This method is called if this device is an MLD to determine the MAC address of the affiliated STA use...
uint32_t m_viMaxAmpduSize
maximum A-MPDU size for AC_VI (in bytes)
Ptr< VhtConfiguration > GetVhtConfiguration() const
Ptr< EhtConfiguration > GetEhtConfiguration() const
Ptr< HtConfiguration > GetHtConfiguration() const
Ptr< HeConfiguration > GetHeConfiguration() const
Ptr< WifiPhy > GetPhy() const
WifiStandard GetStandard() const
Get the configured Wi-Fi standard.
virtual void SetupPhy(const Ptr< WifiPhy > phy)
Set up PHY associated with this device since it is the object that knows the full set of transmit rat...
std::optional< Mac48Address > GetMldAddress(const Mac48Address &address) const
Get the address of the MLD the given station is affiliated with, if any.
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file,...
Ptr< const AttributeAccessor > MakeBooleanAccessor(T1 a1)
Ptr< const AttributeChecker > MakeBooleanChecker()
Ptr< const AttributeAccessor > MakePointerAccessor(T1 a1)
Ptr< const AttributeAccessor > MakeUintegerAccessor(T1 a1)
#define NS_ABORT_MSG_UNLESS(cond, msg)
Abnormal program termination if a condition is false, with a message.
#define NS_FATAL_ERROR(msg)
Report a fatal error with a message and terminate.
#define NS_ABORT_MSG(msg)
Unconditional abnormal program termination with a message.
#define NS_ABORT_UNLESS(cond)
Abnormal program termination if a condition is false.
#define NS_ABORT_MSG_IF(cond, msg)
Abnormal program termination if a condition is true, with a message.
#define NS_ABORT_IF(cond)
Abnormal program termination if a condition is true.
#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.
Time MicroSeconds(uint64_t value)
Construct a Time in the indicated unit.
Time NanoSeconds(uint64_t value)
Construct a Time in the indicated unit.
Ptr< const TraceSourceAccessor > MakeTraceSourceAccessor(T a)
Create a TraceSourceAccessor which will control access to the underlying trace source.
TypeOfStation
Enumeration for type of WiFi station.
WifiStandard
Identifies the IEEE 802.11 specifications that a Wifi device can be configured to use.
AcIndex QosUtilsMapTidToAc(uint8_t tid)
Maps TID (Traffic ID) to Access classes.
WifiQueueBlockedReason
Enumeration of the reasons to block container queues.
AcIndex
This enumeration defines the Access Categories as an enumeration with values corresponding to the AC ...
@ WIFI_STANDARD_UNSPECIFIED
@ WIFI_PHY_BAND_6GHZ
The 6 GHz band.
@ WIFI_PHY_BAND_2_4GHZ
The 2.4 GHz band.
@ WIFI_PHY_BAND_5GHZ
The 5 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)
@ AC_UNDEF
Total number of ACs.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
U * PeekPointer(const Ptr< U > &p)
Callback< R, Args... > MakeCallback(R(T::*memPtr)(Args...), OBJ objPtr)
Build Callbacks for class method members which take varying numbers of arguments and potentially retu...
static constexpr uint8_t SINGLE_LINK_OP_ID
Link ID for single link operations (helps tracking places where correct link ID is to be used to supp...
const std::map< AcIndex, WifiAc > wifiAcList
Map containing the four ACs in increasing order of priority (according to Table 10-1 "UP-to-AC Mappin...
WifiDirection
Wifi direction.
std::map< uint8_t, std::set< uint8_t > > WifiTidLinkMapping
TID-indexed map of the link set to which the TID is mapped.
The different BlockAckRequest variants.
The different BlockAck variants.
@ EHT_MCS_MAP_TYPE_20_MHZ_ONLY
@ EHT_MCS_MAP_TYPE_NOT_LARGER_THAN_80_MHZ
@ EHT_MCS_MAP_TYPE_160_MHZ
uint8_t supportTx1024And4096QamForRuSmallerThan242Tones
Tx 1024-QAM And 4096-QAM < 242-tone RU Support.
uint8_t supportRx1024And4096QamForRuSmallerThan242Tones
Rx 1024-QAM And 4096-QAM < 242-tone RU Support.
Structure holding information specific to a single link.
Ptr< WifiRemoteStationManager > stationManager
Remote station manager (rate control, RTS/CTS/fragmentation thresholds etc.)
Ptr< WifiPhy > phy
Wifi PHY object.
virtual ~LinkEntity()
Destructor (a virtual method is needed to make this struct polymorphic)
bool dsssSupported
set to true iff this WifiMac is to model 802.11b
bool erpSupported
set to true iff this WifiMac is to model 802.11g
Ptr< FrameExchangeManager > feManager
Frame Exchange Manager object.
Ptr< ChannelAccessManager > channelAccessManager
channel access manager object