37#include "ns3/he-configuration.h"
38#include "ns3/ht-configuration.h"
40#include "ns3/multi-link-element.h"
41#include "ns3/packet.h"
42#include "ns3/pointer.h"
43#include "ns3/random-variable-stream.h"
44#include "ns3/simulator.h"
45#include "ns3/string.h"
64 "Delay between two beacons",
68 .AddAttribute(
"BeaconJitter",
69 "A uniform random variable to cause the initial beacon starting time "
70 "(after simulation time 0) "
71 "to be distributed between 0 and the BeaconInterval.",
74 MakePointerChecker<UniformRandomVariable>())
75 .AddAttribute(
"EnableBeaconJitter",
76 "If beacons are enabled, whether to jitter the initial send event.",
80 .AddAttribute(
"BeaconGeneration",
81 "Whether or not beacons are generated.",
85 .AddAttribute(
"EnableNonErpProtection",
86 "Whether or not protection mechanism should be used when non-ERP STAs "
87 "are present within the BSS."
88 "This parameter is only used when ERP is supported by the AP.",
92 .AddAttribute(
"BsrLifetime",
93 "Lifetime of Buffer Status Reports received from stations.",
97 .AddTraceSource(
"AssociatedSta",
98 "A station associated with this access point.",
100 "ns3::ApWifiMac::AssociationCallback")
101 .AddTraceSource(
"DeAssociatedSta",
102 "A station lost association with this access point.",
104 "ns3::ApWifiMac::AssociationCallback");
109 : m_enableBeaconGeneration(false)
140std::unique_ptr<WifiMac::LinkEntity>
143 return std::make_unique<ApLinkEntity>();
161 for (uint8_t linkId = 0; linkId <
GetNLinks(); linkId++)
181 for (uint8_t linkId = 0; linkId <
GetNLinks(); ++linkId)
221 NS_FATAL_ERROR(
"beacon interval should be multiple of 1024us (802.11 time unit), see IEEE "
227 "beacon interval should be smaller then or equal to 65535 * 1024us (802.11 time unit)");
247 for (
const auto& sta : link.staList)
251 link.shortSlotTimeEnabled =
false;
255 link.shortSlotTimeEnabled =
true;
259 link.shortSlotTimeEnabled =
false;
270 for (
const auto& sta : link.staList)
275 link.shortPreambleEnabled =
false;
279 link.shortPreambleEnabled =
true;
283 link.shortPreambleEnabled =
false;
406 for (
const auto& mode :
GetWifiPhy(linkId)->GetModeList())
408 uint64_t modeDataRate = mode.GetDataRate(
GetWifiPhy(linkId)->GetChannelWidth());
409 NS_LOG_DEBUG(
"Adding supported rate of " << modeDataRate);
417 NS_LOG_DEBUG(
"Adding basic mode " << mode.GetUniqueName());
436 for (
const auto& selector :
GetWifiPhy(linkId)->GetBssMembershipSelectorList())
451 return dsssParameters;
474 if (
GetLink(linkId).shortPreambleEnabled)
530 return edcaParameters;
533std::optional<MuEdcaParameterSet>
548 heConfiguration->GetAttribute(
"MuBeAifsn", uintegerValue);
550 heConfiguration->GetAttribute(
"MuBeCwMin", uintegerValue);
552 heConfiguration->GetAttribute(
"MuBeCwMax", uintegerValue);
554 heConfiguration->GetAttribute(
"BeMuEdcaTimer", timeValue);
557 heConfiguration->GetAttribute(
"MuBkAifsn", uintegerValue);
559 heConfiguration->GetAttribute(
"MuBkCwMin", uintegerValue);
561 heConfiguration->GetAttribute(
"MuBkCwMax", uintegerValue);
563 heConfiguration->GetAttribute(
"BkMuEdcaTimer", timeValue);
566 heConfiguration->GetAttribute(
"MuViAifsn", uintegerValue);
568 heConfiguration->GetAttribute(
"MuViCwMin", uintegerValue);
570 heConfiguration->GetAttribute(
"MuViCwMax", uintegerValue);
572 heConfiguration->GetAttribute(
"ViMuEdcaTimer", timeValue);
575 heConfiguration->GetAttribute(
"MuVoAifsn", uintegerValue);
577 heConfiguration->GetAttribute(
"MuVoCwMin", uintegerValue);
579 heConfiguration->GetAttribute(
"MuVoCwMax", uintegerValue);
581 heConfiguration->GetAttribute(
"VoMuEdcaTimer", timeValue);
586 auto timerNotNull = [&muEdcaParameters](uint8_t aci) {
589 auto aci = {0, 1, 2, 3};
590 if (std::all_of(aci.begin(), aci.end(), timerNotNull))
592 return muEdcaParameters;
596 "MU EDCA Timers must be all zero if the IE is not advertised.");
601std::optional<ReducedNeighborReport>
614 for (uint8_t index = 0; index <
GetNLinks(); ++index)
648 staMldAddress.has_value())
650 for (uint8_t i = 0; i <
GetNLinks(); i++)
653 if (
auto staAddress = remoteStationManager->GetAffiliatedStaAddress(*staMldAddress);
654 i != linkId && staAddress.has_value() &&
655 (remoteStationManager->IsWaitAssocTxOk(*staAddress) ||
656 remoteStationManager->IsAssocRefused(*staAddress)))
669 perStaProfile.SetCompleteProfile();
673 perStaProfile.SetAssocResponse(
GetAssocResp(*staAddress, i));
693 if (
phy->GetChannelWidth() > 20)
698 if (
GetLink(linkId).numNonHtStations == 0)
706 uint64_t maxSupportedRate = 0;
709 uint8_t nss = (mcs.GetMcsValue() / 8) + 1;
712 mcs.GetDataRate(
phy->GetChannelWidth(),
715 if (dataRate > maxSupportedRate)
717 maxSupportedRate = dataRate;
718 NS_LOG_DEBUG(
"Updating maxSupportedRate to " << maxSupportedRate);
721 uint8_t maxSpatialStream =
phy->GetMaxSupportedTxSpatialStreams();
723 uint8_t nMcs = mcsList.size();
724 for (
const auto& sta :
GetLink(linkId).staList)
726 if (remoteStationManager->GetHtSupported(sta.second))
728 uint64_t maxSupportedRateByHtSta = 0;
729 auto itMcs = mcsList.begin();
731 j < (
std::min(nMcs, remoteStationManager->GetNMcsSupported(sta.second)));
738 remoteStationManager->GetChannelWidthSupported(sta.second),
739 remoteStationManager->GetShortGuardIntervalSupported(sta.second) ? 400 : 800,
741 if (dataRate > maxSupportedRateByHtSta)
743 maxSupportedRateByHtSta = dataRate;
746 if (maxSupportedRateByHtSta < maxSupportedRate)
748 maxSupportedRate = maxSupportedRateByHtSta;
750 if (remoteStationManager->GetNMcsSupported(sta.second) < nMcs)
752 nMcs = remoteStationManager->GetNMcsSupported(sta.second);
754 if (remoteStationManager->GetNumberOfSupportedStreams(sta.second) < maxSpatialStream)
756 maxSpatialStream = remoteStationManager->GetNumberOfSupportedStreams(sta.second);
761 static_cast<uint16_t
>(maxSupportedRate / 1e6));
788 const uint16_t bssBandwidth =
phy->GetChannelWidth();
798 (bssBandwidth == 160)
800 :
phy->GetChannelNumber());
807 uint8_t maxSpatialStream =
phy->GetMaxSupportedRxSpatialStreams();
808 for (
const auto& sta :
GetLink(linkId).staList)
810 if (remoteStationManager->GetVhtSupported(sta.second))
812 if (remoteStationManager->GetNumberOfSupportedStreams(sta.second) < maxSpatialStream)
814 maxSpatialStream = remoteStationManager->GetNumberOfSupportedStreams(sta.second);
818 for (uint8_t nss = 1; nss <= maxSpatialStream; nss++)
837 for (
const auto& sta :
GetLink(linkId).staList)
839 if (remoteStationManager->GetHeSupported(sta.second))
841 if (remoteStationManager->GetNumberOfSupportedStreams(sta.second) < maxSpatialStream)
843 maxSpatialStream = remoteStationManager->GetNumberOfSupportedStreams(sta.second);
847 for (uint8_t nss = 1; nss <= maxSpatialStream; nss++)
876 GetLink(linkId).shortPreambleEnabled);
878 GetLink(linkId).shortSlotTimeEnabled);
968 if (remoteStationManager->IsWaitAssocTxOk(to))
974 NS_ABORT_IF(!remoteStationManager->IsAssocRefused(to));
976 remoteStationManager->RecordDisassociated(to);
1023 std::list<std::reference_wrapper<MgtAssocResponseHeader>> assocResponses;
1028 assocResponses.push_back(std::ref(assoc));
1029 linkIdStaAddrMap[linkId] = to;
1033 if (mle.has_value())
1037 "Sending a Multi-Link Element to a single link device");
1038 for (std::size_t idx = 0; idx < mle->GetNPerStaProfileSubelements(); idx++)
1040 auto& perStaProfile = mle->GetPerStaProfile(idx);
1041 if (perStaProfile.HasAssocResponse() &&
1042 perStaProfile.GetAssocResponse().GetStatusCode().IsSuccess())
1044 assocResponses.emplace_back(perStaProfile.GetAssocResponse());
1045 uint8_t otherLinkId = perStaProfile.GetLinkId();
1049 "No STA to associate with on link " << +otherLinkId);
1050 const auto [it, inserted] = linkIdStaAddrMap.insert({otherLinkId, *staAddress});
1052 "More than one Association Response to MLD "
1053 << *staMldAddress <<
" on link ID " << +otherLinkId);
1058 if (assocResponses.empty())
1065 std::set<uint16_t> aids;
1066 std::map<uint8_t , uint16_t > linkIdAidMap;
1068 for (
const auto& [
id, staAddr] : linkIdStaAddrMap)
1070 for (
const auto& [aid, addr] :
GetLink(
id).staList)
1072 if (addr == staAddr)
1075 linkIdAidMap[id] = aid;
1083 while (!aids.empty())
1085 const uint16_t aid = *aids.begin();
1088 for (
const auto& [
id, staAddr] : linkIdStaAddrMap)
1090 if (
auto it =
GetLink(
id).staList.find(aid);
1091 it !=
GetLink(
id).staList.end() && it->second != staAddr)
1095 aids.erase(aids.begin());
1113 aid = *aids.begin();
1117 std::list<uint8_t> linkIds;
1118 std::transform(linkIdStaAddrMap.cbegin(),
1119 linkIdStaAddrMap.cend(),
1120 std::back_inserter(linkIds),
1121 [](
auto&& linkIdStaAddrPair) { return linkIdStaAddrPair.first; });
1125 for (
const auto& [
id, staAddr] : linkIdStaAddrMap)
1130 if (
auto it = linkIdAidMap.find(
id); it == linkIdAidMap.end() || it->second != aid)
1133 link.staList.insert(std::make_pair(aid, staAddr));
1135 remoteStationManager->SetAssociationId(staAddr, aid);
1137 if (it == linkIdAidMap.end())
1140 if (remoteStationManager->GetDsssSupported(staAddr) &&
1141 !remoteStationManager->GetErpOfdmSupported(staAddr))
1143 link.numNonErpStations++;
1145 if (!remoteStationManager->GetHtSupported(staAddr))
1147 link.numNonHtStations++;
1155 link.staList.erase(it->second);
1165 for (
auto& assocResp : assocResponses)
1167 assocResp.get().SetAssociationId(aid);
1197 SetAid(assoc, to, linkId);
1231 hdr.
SetAddr2(link.feManager->GetAddress());
1232 hdr.
SetAddr3(link.feManager->GetAddress());
1315 if (link.shortSlotTimeEnabled)
1345 if (
auto staMldAddress =
1347 staMldAddress.has_value())
1350 for (uint8_t i = 0; i <
GetNLinks(); i++)
1353 if (
auto staAddress = stationManager->GetAffiliatedStaAddress(*staMldAddress);
1354 staAddress.has_value() && i != *linkId &&
1355 stationManager->IsWaitAssocTxOk(*staAddress))
1358 <<
" associated with STA=" << *staAddress);
1359 stationManager->RecordGotAssocTxOk(*staAddress);
1380 <<
" association failed with STA=" << hdr.
GetAddr1());
1384 if (
auto staMldAddress =
1386 staMldAddress.has_value())
1389 for (uint8_t i = 0; i <
GetNLinks(); i++)
1392 if (
auto staAddress = stationManager->GetAffiliatedStaAddress(*staMldAddress);
1393 staAddress.has_value() && i != *linkId &&
1394 stationManager->IsWaitAssocTxOk(*staAddress))
1397 <<
" association failed with STA=" << *staAddress);
1398 stationManager->RecordGotAssocTxFailed(*staAddress);
1427 <<
", size=" << packet->
GetSize());
1443 NS_LOG_DEBUG(
"forwarding frame from=" << from <<
", to=" << to);
1478 else if (hdr->
IsMgt())
1498 NS_LOG_DEBUG(
"Probe request received from " << from <<
": send probe response");
1508 <<
" request received from " << from
1509 << ((
GetNLinks() > 1) ?
" on link ID " + std::to_string(linkId) :
""));
1536 for (
auto it = staList.begin(); it != staList.end(); ++it)
1538 if (it->second == from)
1576 auto failure = [&](
const std::string& msg) ->
bool {
1577 NS_LOG_DEBUG(
"Association Request from " << from <<
" refused: " << msg);
1578 remoteStationManager->RecordAssocRefused(from);
1583 auto recvAssocRequest = [&](
auto&& frameRefWrapper) ->
bool {
1584 const auto& frame = frameRefWrapper.get();
1589 remoteStationManager->AddSupportedPhyPreamble(from, capabilities.
IsShortPreamble());
1594 return failure(
"STA's supported rate set not compatible with our Basic Rate set");
1600 const auto& htCapabilities = frame.GetHtCapabilities();
1601 if (htCapabilities.has_value() && htCapabilities->IsSupportedMcs(0))
1603 for (uint8_t i = 0; i < remoteStationManager->GetNBasicMcs(); i++)
1605 WifiMode mcs = remoteStationManager->GetBasicMcs(i);
1606 if (!htCapabilities->IsSupportedMcs(mcs.
GetMcsValue()))
1608 return failure(
"HT STA does not support all MCSs in Basic MCS Set");
1616 const auto& vhtCapabilities = frame.GetVhtCapabilities();
1617 if (vhtCapabilities.has_value() && vhtCapabilities->GetVhtCapabilitiesInfo() != 0)
1619 for (uint8_t i = 0; i < remoteStationManager->GetNBasicMcs(); i++)
1621 WifiMode mcs = remoteStationManager->GetBasicMcs(i);
1622 if (!vhtCapabilities->IsSupportedTxMcs(mcs.
GetMcsValue()))
1624 return failure(
"VHT STA does not support all MCSs in Basic MCS Set");
1632 const auto& heCapabilities = frame.GetHeCapabilities();
1633 if (heCapabilities.has_value() && heCapabilities->GetSupportedMcsAndNss() != 0)
1635 for (uint8_t i = 0; i < remoteStationManager->GetNBasicMcs(); i++)
1637 WifiMode mcs = remoteStationManager->GetBasicMcs(i);
1638 if (!heCapabilities->IsSupportedTxMcs(mcs.
GetMcsValue()))
1640 return failure(
"HE STA does not support all MCSs in Basic MCS Set");
1656 for (
const auto& mode :
phy->GetModeList())
1660 remoteStationManager->AddSupportedMode(from, mode);
1663 if (
GetErpSupported(linkId) && remoteStationManager->GetErpOfdmSupported(from) &&
1666 remoteStationManager->AddSupportedErpSlotTime(from,
true);
1670 const auto& htCapabilities = frame.GetHtCapabilities();
1671 if (htCapabilities.has_value() && htCapabilities->IsSupportedMcs(0))
1673 remoteStationManager->AddStationHtCapabilities(from, *htCapabilities);
1680 const auto& vhtCapabilities = frame.GetVhtCapabilities();
1683 if (vhtCapabilities.has_value() &&
1684 vhtCapabilities->GetRxHighestSupportedLgiDataRate() > 0)
1686 remoteStationManager->AddStationVhtCapabilities(from, *vhtCapabilities);
1689 if (vhtCapabilities->IsSupportedTxMcs(mcs.GetMcsValue()))
1691 remoteStationManager->AddSupportedMcs(from, mcs);
1699 const auto& heCapabilities = frame.GetHeCapabilities();
1700 if (heCapabilities.has_value() && heCapabilities->GetSupportedMcsAndNss() != 0)
1702 remoteStationManager->AddStationHeCapabilities(from, *heCapabilities);
1705 if (heCapabilities->IsSupportedTxMcs(mcs.GetMcsValue()))
1707 remoteStationManager->AddSupportedMcs(from, mcs);
1715 const auto& ehtCapabilities = frame.GetEhtCapabilities();
1718 remoteStationManager->AddStationEhtCapabilities(from, *ehtCapabilities);
1722 remoteStationManager->AddSupportedMcs(from, mcs);
1727 NS_LOG_DEBUG(
"Association Request from " << from <<
" accepted");
1728 remoteStationManager->RecordWaitAssocTxOk(from);
1733 return std::visit(recvAssocRequest, assoc);
1742 auto recvMle = [&](
auto&& frame) {
1743 const auto& mle = frame.get().GetMultiLinkElement();
1745 if (!mle.has_value())
1752 for (std::size_t i = 0; i < mle->GetNPerStaProfileSubelements(); i++)
1754 auto& perStaProfile = mle->GetPerStaProfile(i);
1755 if (!perStaProfile.HasStaMacAddress())
1758 <<
"] Cannot setup a link if the STA MAC address is missing");
1761 uint8_t newLinkId = perStaProfile.GetLinkId();
1762 if (newLinkId == linkId || newLinkId >=
GetNLinks())
1764 NS_LOG_DEBUG(
"[i=" << i <<
"] Link ID " << newLinkId <<
" not valid");
1767 if (!perStaProfile.HasAssocRequest() && !perStaProfile.HasReassocRequest())
1769 NS_LOG_DEBUG(
"[i=" << i <<
"] No (Re)Association Request frame body present");
1774 perStaProfile.GetStaMacAddress(),
1777 mle->GetMldMacAddress());
1781 std::visit(recvMle, assoc);
1790 if (i.second.GetDestinationAddr() ==
GetAddress())
1792 ForwardUp(i.first, i.second.GetSourceAddr(), i.second.GetDestinationAddr());
1798 NS_LOG_DEBUG(
"forwarding QoS frame from=" << from <<
", to=" << to);
1799 ForwardDown(i.first->Copy(), from, to, mpdu->GetHeader().GetQosTid());
1810 for (uint8_t linkId = 0; linkId <
GetNLinks(); ++linkId)
1820 NS_LOG_DEBUG(
"Scheduling initial beacon for access point "
1821 <<
GetAddress() <<
" at time " << jitterUs <<
"us");
1842 return useProtection;
1849 for (uint16_t nextAid = 1; nextAid <= 2007; nextAid++)
1851 if (std::all_of(linkIds.begin(), linkIds.end(), [&](
auto&& linkId) {
1852 auto& staList = GetLink(linkId).staList;
1853 return staList.find(nextAid) == staList.end();
1863const std::map<uint16_t, Mac48Address>&
1883 return it->second.value;
1903 uint8_t maxSize = 0;
1906 for (uint8_t tid = 0; tid < 8; tid++)
void SendAssocResp(Mac48Address to, bool isReassoc, uint8_t linkId)
Forward an association or a reassociation response packet to the DCF/EDCA.
uint16_t GetAssociationId(Mac48Address addr, uint8_t linkId) const
std::unique_ptr< LinkEntity > CreateLinkEntity() const override
Create a LinkEntity object.
Ptr< Txop > m_beaconTxop
Dedicated Txop for beacons.
void SetBeaconGeneration(bool enable)
Enable or disable beacon generation of the AP.
void ParseReportedStaInfo(const AssocReqRefVariant &assoc, Mac48Address from, uint8_t linkId)
Given a (Re)Association Request frame body containing a Multi-Link Element, check if a link can be se...
void SetAid(MgtAssocResponseHeader &assoc, const Mac48Address &to, uint8_t linkId)
Set the AID field of the given Association Response frame, which is going to be sent to the STA with ...
void UpdateShortSlotTimeEnabled(uint8_t linkId)
Update whether short slot time should be enabled or not in the BSS corresponding to the given link.
void DoDispose() override
Destructor implementation.
void SetBeaconInterval(Time interval)
bool ReceiveAssocRequest(const AssocReqRefVariant &assoc, const Mac48Address &from, uint8_t linkId)
Check whether the supported rate set included in the received (Re)Association Request frame is compat...
CapabilityInformation GetCapabilities(uint8_t linkId) const
Return the Capability information of the current AP for the given link.
Ptr< UniformRandomVariable > m_beaconJitter
UniformRandomVariable used to randomize the time of the first beacon.
SupportedRates GetSupportedRates(uint8_t linkId) const
Return an instance of SupportedRates that contains all rates that we support for the given link (incl...
bool CanForwardPacketsTo(Mac48Address to) const override
Return true if packets can be forwarded to the given destination, false otherwise.
bool m_enableNonErpProtection
Flag whether protection mechanism is used or not when non-ERP STAs are present within the BSS.
EdcaParameterSet GetEdcaParameterSet(uint8_t linkId) const
Return the EDCA Parameter Set of the current AP for the given link.
MultiLinkElement GetMultiLinkElement(uint8_t linkId, WifiMacType frameType, const Mac48Address &to=Mac48Address::GetBroadcast())
Return the Multi-Link Element that the current AP includes in the management frames of the given type...
HtOperation GetHtOperation(uint8_t linkId) const
Return the HT operation of the current AP for the given link.
void UpdateShortPreambleEnabled(uint8_t linkId)
Update whether short preamble should be enabled or not in the BSS corresponding to the given link.
void TxOk(Ptr< const WifiMpdu > mpdu)
The packet we sent was successfully received by the receiver (i.e.
TracedCallback< uint16_t, Mac48Address > m_deAssocLogger
deassociation logger
bool m_enableBeaconGeneration
Flag whether beacons are being generated.
Time m_beaconInterval
Beacon interval.
uint16_t GetNextAssociationId(std::list< uint8_t > linkIds)
bool m_enableBeaconJitter
Flag whether the first beacon should be generated at random time.
void SendProbeResp(Mac48Address to, uint8_t linkId)
Send a Probe Response in response to a Probe Request received from the STA with the given address on ...
DsssParameterSet GetDsssParameterSet(uint8_t linkId) const
Return the DSSS Parameter Set that we support on the given link.
TracedCallback< uint16_t, Mac48Address > m_assocLogger
association logger
Time GetBeaconInterval() const
static TypeId GetTypeId()
Get the type ID.
std::optional< ReducedNeighborReport > GetReducedNeighborReport(uint8_t linkId) const
Return the Reduced Neighbor Report (RNR) element that the current AP sends on the given link,...
void Enqueue(Ptr< Packet > packet, Mac48Address to) override
uint8_t GetMaxBufferStatus(Mac48Address address) const
Return the maximum among the values of the Queue Size subfield of the last QoS Data or QoS Null frame...
Time m_bsrLifetime
Lifetime of Buffer Status Reports.
int64_t AssignStreams(int64_t stream)
Assign a fixed random variable stream number to the random variables used by this model.
ApLinkEntity & GetLink(uint8_t linkId) const
Get a reference to the link associated with the given ID.
void Receive(Ptr< const WifiMpdu > mpdu, uint8_t linkId) override
This method acts as the MacRxMiddle receive callback and is invoked to notify us that a frame has bee...
uint8_t GetBufferStatus(uint8_t tid, Mac48Address address) const
Return the value of the Queue Size subfield of the last QoS Data or QoS Null frame received from the ...
void ConfigureStandard(WifiStandard standard) override
ErpInformation GetErpInformation(uint8_t linkId) const
Return the ERP information of the current AP for the given link.
void SetLinkUpCallback(Callback< void > linkUp) override
VhtOperation GetVhtOperation(uint8_t linkId) const
Return the VHT operation of the current AP for the given link.
void TxFailed(WifiMacDropReason timeoutReason, Ptr< const WifiMpdu > mpdu)
The packet we sent was successfully received by the receiver (i.e.
HeOperation GetHeOperation(uint8_t linkId) const
Return the HE operation of the current AP for the given link.
void SetBufferStatus(uint8_t tid, Mac48Address address, uint8_t size)
Store the value of the Queue Size subfield of the last QoS Data or QoS Null frame received from the s...
std::optional< MuEdcaParameterSet > GetMuEdcaParameterSet() const
Return the MU EDCA Parameter Set of the current AP, if one needs to be advertised.
void DeaggregateAmsduAndForward(Ptr< const WifiMpdu > mpdu) override
This method is called to de-aggregate an A-MSDU and forward the constituent packets up the stack.
bool SupportsSendFrom() const override
std::unordered_map< WifiAddressTidPair, bsrType, WifiAddressTidHash > m_bufferStatus
Per (MAC address, TID) buffer status reports.
MgtAssocResponseHeader GetAssocResp(Mac48Address to, uint8_t linkId)
Get the Association Response frame to send on a given link.
void ForwardDown(Ptr< Packet > packet, Mac48Address from, Mac48Address to)
Forward the packet down to DCF/EDCAF (enqueue the packet).
void DoInitialize() override
Initialize() implementation.
void SendOneBeacon(uint8_t linkId)
Forward a beacon packet to the beacon special DCF for transmission on the given link.
Ptr< WifiMacQueue > GetTxopQueue(AcIndex ac) const override
Get the wifi MAC queue of the (Qos)Txop associated with the given AC, if such (Qos)Txop is installed,...
const std::map< uint16_t, Mac48Address > & GetStaList(uint8_t linkId=SINGLE_LINK_OP_ID) const
Get a const reference to the map of associated stations on the given link.
bool GetUseNonErpProtection(uint8_t linkId) const
Return whether protection for non-ERP stations is used in the BSS corresponding to the given link.
AttributeValue implementation for Boolean.
void Add(Ptr< Txop > txop)
void SetCurrentChannel(uint8_t currentChannel)
Set the Current Channel field in the DsssParameterSet information element.
void SetViTxopLimit(uint16_t txop)
Set the AC_VI TXOP Limit field in the EdcaParameterSet information element.
void SetViAifsn(uint8_t aifsn)
Set the AC_VI AIFSN field in the EdcaParameterSet information element.
void SetVoAci(uint8_t aci)
Set the AC_VO ACI field in the EdcaParameterSet information element.
void SetVoCWmax(uint32_t cwMax)
Set the AC_VO CWmax field in the EdcaParameterSet information element.
void SetViCWmin(uint32_t cwMin)
Set the AC_VI CWmin field in the EdcaParameterSet information element.
void SetVoTxopLimit(uint16_t txop)
Set the AC_VO TXOP Limit field in the EdcaParameterSet information element.
void SetVoAifsn(uint8_t aifsn)
Set the AC_VO AIFSN field in the EdcaParameterSet information element.
void SetQosInfo(uint8_t qosInfo)
Set the QoS Info field in the EdcaParameterSet information element.
void SetBkCWmin(uint32_t cwMin)
Set the AC_BK CWmin field in the EdcaParameterSet information element.
void SetViAci(uint8_t aci)
Set the AC_VI ACI field in the EdcaParameterSet information element.
void SetViCWmax(uint32_t cwMax)
Set the AC_VI CWmax field in the EdcaParameterSet information element.
void SetVoCWmin(uint32_t cwMin)
Set the AC_VO CWmin field in the EdcaParameterSet information element.
void SetBeTxopLimit(uint16_t txop)
Set the AC_BE TXOP Limit field in the EdcaParameterSet information element.
void SetBeCWmax(uint32_t cwMax)
Set the AC_BE CWmax field in the EdcaParameterSet information element.
void SetBeAci(uint8_t aci)
Set the AC_BE ACI field in the EdcaParameterSet information element.
void SetBkCWmax(uint32_t cwMax)
Set the AC_BK CWmax field in the EdcaParameterSet information element.
void SetBkTxopLimit(uint16_t txop)
Set the AC_BK TXOP Limit field in the EdcaParameterSet information element.
void SetBkAifsn(uint8_t aifsn)
Set the AC_BK AIFSN field in the EdcaParameterSet information element.
void SetBeCWmin(uint32_t cwMin)
Set the AC_BE CWmin field in the EdcaParameterSet information element.
void SetBkAci(uint8_t aci)
Set the AC_BK ACI field in the EdcaParameterSet information element.
void SetBeAifsn(uint8_t aifsn)
Set the AC_BE AIFSN field in the EdcaParameterSet information element.
void Cancel()
This method is syntactic sugar for the ns3::Simulator::Cancel method.
The HE Operation Information Element.
void SetBssColor(uint8_t bssColor)
Set the BSS color.
void SetMaxHeMcsPerNss(uint8_t nss, uint8_t maxHeMcs)
Set the Basic HE-MCS and NSS field in the HE Operation information element by specifying the tuple (n...
The HT Operation Information Element.
void SetObssNonHtStasPresent(uint8_t obssNonHtStasPresent)
Set the OBSS non HT STAs present.
void SetRifsMode(uint8_t rifsMode)
Set the RIFS mode.
void SetSecondaryChannelOffset(uint8_t secondaryChannelOffset)
Set the secondary channel offset.
void SetPcoActive(uint8_t pcoActive)
Set the PCO active.
void SetTxUnequalModulation(uint8_t txUnequalModulation)
Set the transmit unequal modulation.
void SetHtProtection(uint8_t htProtection)
Set the HT protection.
void SetTxMaxNSpatialStreams(uint8_t maxTxSpatialStreams)
Set the transmit maximum number spatial streams.
void SetTxRxMcsSetUnequal(uint8_t txRxMcsSetUnequal)
Set the transmit / receive MCS set unequal.
void SetDualBeacon(uint8_t dualBeacon)
Set the dual beacon.
void SetNonGfHtStasPresent(uint8_t nonGfHtStasPresent)
Set the non GF HT STAs present.
void SetTxMcsSetDefined(uint8_t txMcsSetDefined)
Set the transmit MCS set defined.
void SetLSigTxopProtectionFullSupport(uint8_t lSigTxopProtectionFullSupport)
Set the LSIG TXOP protection full support.
void SetStaChannelWidth(uint8_t staChannelWidth)
Set the STA channel width.
void SetRxHighestSupportedDataRate(uint16_t maxSupportedRate)
Set the receive highest supported data rate.
void SetRxMcsBitmask(uint8_t index)
Set the receive MCS bitmask.
void SetPrimaryChannel(uint8_t ctrl)
Set the Primary Channel field in the HT Operation information element.
void SetDualCtsProtection(uint8_t dualCtsProtection)
Set the dual CTS protection.
void SetPhase(uint8_t pcoPhase)
Set the PCO phase.
void SetStbcBeacon(uint8_t stbcBeacon)
Set the STBC beacon.
static Mac48Address GetBroadcast()
The MU EDCA Parameter Set.
void SetMuCwMin(uint8_t aci, uint16_t cwMin)
Set the ECWmin subfield of the ECWmin/ECWmax field in the MU AC Parameter Record field corresponding ...
void SetMuEdcaTimer(uint8_t aci, Time timer)
Set the MU EDCA Timer field in the MU AC Parameter Record field corresponding to the given AC Index (...
void SetMuAifsn(uint8_t aci, uint8_t aifsn)
Set the AIFSN subfield of the ACI/AIFSN field in the MU AC Parameter Record field corresponding to th...
void SetQosInfo(uint8_t qosInfo)
Set the QoS Info field in the MuEdcaParameterSet information element.
Time GetMuEdcaTimer(uint8_t aci) const
Get the MU EDCA Timer value encoded in the MU AC Parameter Record field corresponding to the given AC...
void SetMuCwMax(uint8_t aci, uint16_t cwMax)
Set the ECWmax subfield of the ECWmin/ECWmax field in the MU AC Parameter Record field corresponding ...
void SetLinkId(uint8_t linkId)
Set the Link ID subfield in the STA Control field.
void AddPerStaProfileSubelement()
Add a Per-STA Profile Subelement in the Link Info field.
void SetBssParamsChangeCount(uint8_t count)
Set the BSS Parameters Change Count subfield in the Common Info field.
void SetLinkIdInfo(uint8_t linkIdInfo)
Set the Link ID Info subfield in the Common Info field.
PerStaProfileSubelement & GetPerStaProfile(std::size_t i)
Get a reference to the i-th Per-STA Profile Subelement in the Link Info field.
void SetMldMacAddress(Mac48Address address)
Set the MLD MAC Address subfield in the Common Info field.
std::size_t GetNPerStaProfileSubelements() const
Return the number of Per-STA Profile Subelement in the Link Info field.
bool TraceConnectWithoutContext(std::string name, const CallbackBase &cb)
Connect a TraceSource to a Callback without a context.
void Initialize()
Invoke DoInitialize on all Objects aggregated to this one.
void Dispose()
Dispose of this Object.
void AddHeader(const Header &header)
Add header to this packet.
uint32_t GetSize() const
Returns the the size in bytes of the packet (including the zero-filled initial payload).
Ptr< Packet > Copy() const
performs a COW copy of the packet.
uint32_t PeekHeader(Header &header) const
Deserialize but does not remove the header from the internal buffer.
Smart pointer class similar to boost::intrusive_ptr.
uint8_t GetAifsn(uint8_t linkId) const override
For the given link, return the number of slots that make up an AIFS according to the EDCA Parameter S...
uint32_t GetMinCw(uint8_t linkId) const override
For the given link, return the minimum contention window size from the EDCA Parameter Set or the MU E...
uint32_t GetMaxCw(uint8_t linkId) const override
For the given link, return the maximum contention window size from the EDCA Parameter Set or the MU E...
void SetStream(int64_t stream)
Specifies the stream number for the RngStream.
The Reduced Neighbor Report element.
std::size_t GetNNbrApInfoFields() const
Get the number of Neighbor AP Information fields.
void SetMldParameters(std::size_t nbrApInfoId, std::size_t index, uint8_t mldId, uint8_t linkId, uint8_t changeSequence)
Set the MLD Parameters subfield of the i-th TBTT Information field of the given Neighbor AP Informati...
void SetShortSsid(std::size_t nbrApInfoId, std::size_t index, uint32_t shortSsid)
Set the Short SSID field of the i-th TBTT Information field of the given Neighbor AP Information fiel...
void SetBssid(std::size_t nbrApInfoId, std::size_t index, Mac48Address bssid)
Set the BSSID field of the i-th TBTT Information field of the given Neighbor AP Information field.
void SetPsd20MHz(std::size_t nbrApInfoId, std::size_t index, uint8_t psd20MHz)
Set the 20 MHz PSD field of the i-th TBTT Information field of the given Neighbor AP Information fiel...
void AddNbrApInfoField()
Add a Neighbor AP Information field.
void SetBssParameters(std::size_t nbrApInfoId, std::size_t index, uint8_t bssParameters)
Set the BSS Parameters field of the i-th TBTT Information field of the given Neighbor AP Information ...
void AddTbttInformationField(std::size_t nbrApInfoId)
Add a TBTT Information fields to the TBTT Information Set field of the given Neighbor AP Information ...
void SetOperatingChannel(std::size_t nbrApInfoId, const WifiPhyOperatingChannel &channel)
Set the Operating Class and the Channel Number fields of the given Neighbor AP Information field base...
static EventId Schedule(const Time &delay, FUNC f, Ts &&... args)
Schedule an event to expire after delay.
static Time Now()
Return the current simulation virtual time.
static EventId ScheduleNow(FUNC f, Ts &&... args)
Schedule an event to expire Now.
The IEEE 802.11 SSID Information Element.
Status code for association response.
bool IsSuccess() const
Return whether the status code is success.
void SetFailure()
Set success bit to 1 (failure).
void SetSuccess()
Set success bit to 0 (success).
Hold variables of type string.
The Supported Rates Information Element.
void SetBasicRate(uint64_t bs)
Set the given rate to basic rates.
void AddBssMembershipSelectorRate(uint64_t bs)
Add a special value to the supported rate set, corresponding to a BSS membership selector.
uint8_t GetNRates() const
Return the number of supported rates.
void AddSupportedRate(uint64_t bs)
Add the given rate to the supported rates.
bool IsSupportedRate(uint64_t bs) const
Check if the given rate is supported.
Simulation virtual time values and global simulation resolution.
bool IsZero() const
Exactly equivalent to t == 0.
int64_t GetMicroSeconds() const
Get an approximation of the time stored in this instance in the indicated unit.
AttributeValue implementation for Time.
Time GetTxopLimit() const
Return the TXOP limit.
Ptr< WifiMacQueue > GetWifiMacQueue() const
Return the packet queue associated with this Txop.
virtual void SetWifiMac(const Ptr< WifiMac > mac)
Set the wifi MAC this Txop is associated to.
void SetMaxCws(std::vector< uint32_t > maxCws)
Set the maximum contention window size for each link.
void SetTxMiddle(const Ptr< MacTxMiddle > txMiddle)
Set MacTxMiddle this Txop is associated to.
void SetMinCws(std::vector< uint32_t > minCws)
Set the minimum contention window size for each link.
void SetAifsns(std::vector< uint8_t > aifsns)
Set the number of slots that make up an AIFS for each link.
virtual void Queue(Ptr< Packet > packet, const WifiMacHeader &hdr)
a unique identifier for an interface.
TypeId SetParent(TypeId tid)
Set the parent TypeId.
Hold an unsigned integer type.
The VHT Operation Information Element.
void SetMaxVhtMcsPerNss(uint8_t nss, uint8_t maxVhtMcs)
Set the Basic VHT-MCS and NSS field in the VHT Operation information element by specifying the tuple ...
void SetChannelWidth(uint8_t channelWidth)
Set the Channel Width field in the VHT Operation information element.
void SetChannelCenterFrequencySegment1(uint8_t channelCenterFrequencySegment1)
Set the Channel Center Frequency Segment 1 field in the VHT Operation information element.
void SetChannelCenterFrequencySegment0(uint8_t channelCenterFrequencySegment0)
Set the Channel Center Frequency Segment 0 field in the VHT Operation information element.
base class for all MAC-level wifi objects.
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.
Ptr< HeConfiguration > GetHeConfiguration() 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.
bool GetQosSupported() const
Return whether the device supports QoS.
uint8_t GetNLinks() const
Get the number of links (can be greater than 1 for 11be devices only).
void DoInitialize() override
Initialize() implementation.
virtual void ConfigureStandard(WifiStandard standard)
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.
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.
Ptr< WifiPhy > GetWifiPhy(uint8_t linkId=SINGLE_LINK_OP_ID) const
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.
virtual std::optional< uint8_t > GetLinkIdByAddress(const Mac48Address &address) const
Get the ID of the link having the given MAC address, if any.
bool GetVhtSupported(uint8_t linkId) const
Return whether the device supports VHT on the given link.
Ptr< MacTxMiddle > m_txMiddle
TX middle (aggregation etc.)
Ptr< HtConfiguration > GetHtConfiguration() const
ExtendedCapabilities GetExtendedCapabilities() const
Return the extended capabilities of the device.
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,...
bool GetShortSlotTimeSupported() const
void NotifyRxDrop(Ptr< const Packet > packet)
virtual void SetLinkUpCallback(Callback< void > linkUp)
Ptr< WifiRemoteStationManager > GetWifiRemoteStationManager(uint8_t linkId=0) const
void ForwardUp(Ptr< const Packet > packet, Mac48Address from, Mac48Address to)
Forward the packet up to the device.
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
EhtCapabilities GetEhtCapabilities(uint8_t linkId) const
Return the EHT capabilities of the device for the given link.
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.
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.
represent a single transmission mode
std::string GetUniqueName() const
uint64_t GetDataRate(uint16_t channelWidth, uint16_t guardInterval, uint8_t nss) const
uint8_t GetMcsValue() const
uint8_t GetMaxSupportedRxSpatialStreams() const
void SetSlot(Time slot)
Set the slot duration for this PHY.
const WifiPhyOperatingChannel & GetOperatingChannel() const
Get a const reference to the operating channel.
void SetShortSlotTimeEnabled(bool enable)
Enable or disable short slot time.
void AddBasicMode(WifiMode mode)
Invoked in a STA upon association to store the set of rates which belong to the BSSBasicRateSet of th...
uint16_t GetAssociationId(Mac48Address remoteAddress) const
Get the AID of a remote station.
uint8_t GetNBasicModes() const
Return the number of basic modes we support.
void SetUseNonErpProtection(bool enable)
Enable or disable protection for non-ERP stations.
std::optional< Mac48Address > GetAffiliatedStaAddress(const Mac48Address &mldAddress) const
Get the address of the remote station operating on this link and affiliated with the MLD having the g...
void SetShortPreambleEnabled(bool enable)
Enable or disable short PHY preambles.
void SetMldAddress(const Mac48Address &address, const Mac48Address &mldAddress)
Set the address of the MLD the given station is affiliated with.
void RecordGotAssocTxOk(Mac48Address address)
Records that we got an ACK for the association response we sent.
WifiMode GetBasicMode(uint8_t i) const
Return a basic mode from the set of basic modes.
void RecordDisassociated(Mac48Address address)
Records that the STA was disassociated.
void RecordGotAssocTxFailed(Mac48Address address)
Records that we missed an ACK for the association response we sent.
std::optional< Mac48Address > GetMldAddress(const Mac48Address &address) const
Get the address of the MLD the given station is affiliated with, if any.
bool IsWaitAssocTxOk(Mac48Address address) const
Return whether we are waiting for an ACK for the association response we sent.
#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 > MakeTimeAccessor(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_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_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_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 MilliSeconds(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.
WifiStandard
Identifies the IEEE 802.11 specifications that a Wifi device can be configured to use.
WifiMacDropReason
The reason why an MPDU was dropped.
uint8_t QosUtilsGetTidForPacket(Ptr< const Packet > packet)
If a QoS tag is attached to the packet, returns a value < 8.
AcIndex
This enumeration defines the Access Categories as an enumeration with values corresponding to the AC ...
@ WIFI_MOD_CLASS_HR_DSSS
HR/DSSS (Clause 16)
@ 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.
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...
std::variant< std::reference_wrapper< MgtAssocRequestHeader >, std::reference_wrapper< MgtReassocRequestHeader > > AssocReqRefVariant
variant holding a reference to a (Re)Association Request
Ptr< const AttributeChecker > MakeTimeChecker(const Time min, const Time max)
Helper to make a Time checker with bounded range.
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...
WifiMacType
Combination of valid MAC header type/subtype.
@ WIFI_MAC_MGT_ASSOCIATION_RESPONSE
@ WIFI_MAC_MGT_PROBE_RESPONSE
@ WIFI_MAC_MGT_REASSOCIATION_RESPONSE
std::pair< Mac48Address, uint8_t > WifiAddressTidPair
(MAC address, TID) pair
Structure holding information specific to a single link.
std::map< uint16_t, Mac48Address > staList
Map of all stations currently associated to the AP with their association ID.
EventId beaconEvent
Event to generate one beacon.
~ApLinkEntity() override
Destructor (a virtual method is needed to make this struct polymorphic)
uint16_t numNonHtStations
Number of non-HT stations currently associated to the AP.
uint16_t numNonErpStations
Number of non-ERP stations currently associated to the AP.
Ptr< WifiPhy > phy
Wifi PHY object.
Ptr< FrameExchangeManager > feManager
Frame Exchange Manager object.
Ptr< ChannelAccessManager > channelAccessManager
channel access manager object