30#include "ns3/boolean.h" 
   31#include "ns3/eht-configuration.h" 
   33#include "ns3/erp-ofdm-phy.h" 
   34#include "ns3/he-configuration.h" 
   35#include "ns3/ht-configuration.h" 
   36#include "ns3/ht-phy.h" 
   38#include "ns3/simulator.h" 
   39#include "ns3/uinteger.h" 
   40#include "ns3/vht-configuration.h" 
   53        TypeId(
"ns3::WifiRemoteStationManager")
 
   56            .AddAttribute(
"MaxSsrc",
 
   57                          "The maximum number of retransmission attempts for any packet with size " 
   58                          "<= RtsCtsThreshold. " 
   59                          "This value will not have any effect on some rate control algorithms.",
 
   62                          MakeUintegerChecker<uint32_t>())
 
   63            .AddAttribute(
"MaxSlrc",
 
   64                          "The maximum number of retransmission attempts for any packet with size " 
   66                          "This value will not have any effect on some rate control algorithms.",
 
   69                          MakeUintegerChecker<uint32_t>())
 
   70            .AddAttribute(
"RtsCtsThreshold",
 
   71                          "If the size of the PSDU is bigger than this value, we use an RTS/CTS " 
   72                          "handshake before sending the data frame." 
   73                          "This value will not have any effect on some rate control algorithms.",
 
   76                          MakeUintegerChecker<uint32_t>())
 
   78                "FragmentationThreshold",
 
   79                "If the size of the PSDU is bigger than this value, we fragment it such that the " 
   80                "size of the fragments are equal or smaller. " 
   81                "This value does not apply when it is carried in an A-MPDU. " 
   82                "This value will not have any effect on some rate control algorithms.",
 
   86                MakeUintegerChecker<uint32_t>())
 
   87            .AddAttribute(
"NonUnicastMode",
 
   88                          "Wifi mode used for non-unicast transmissions.",
 
   91                          MakeWifiModeChecker())
 
   92            .AddAttribute(
"DefaultTxPowerLevel",
 
   93                          "Default power level to be used for transmissions. " 
   94                          "This is the power level that is used by all those WifiManagers that do " 
   95                          "not implement TX power control.",
 
   98                          MakeUintegerChecker<uint8_t>())
 
   99            .AddAttribute(
"ErpProtectionMode",
 
  100                          "Protection mode used when non-ERP STAs are connected to an ERP AP: " 
  101                          "Rts-Cts or Cts-To-Self",
 
  108            .AddAttribute(
"HtProtectionMode",
 
  109                          "Protection mode used when non-HT STAs are connected to a HT AP: Rts-Cts " 
  117            .AddTraceSource(
"MacTxRtsFailed",
 
  118                            "The transmission of a RTS by the MAC layer has failed",
 
  120                            "ns3::Mac48Address::TracedCallback")
 
  121            .AddTraceSource(
"MacTxDataFailed",
 
  122                            "The transmission of a data packet by the MAC layer has failed",
 
  124                            "ns3::Mac48Address::TracedCallback")
 
  126                "MacTxFinalRtsFailed",
 
  127                "The transmission of a RTS has exceeded the maximum number of attempts",
 
  129                "ns3::Mac48Address::TracedCallback")
 
  131                "MacTxFinalDataFailed",
 
  132                "The transmission of a data packet has exceeded the maximum number of attempts",
 
  134                "ns3::Mac48Address::TracedCallback");
 
  139    : m_useNonErpProtection(false),
 
  140      m_useNonHtProtection(false),
 
  141      m_shortPreambleEnabled(false),
 
  142      m_shortSlotTimeEnabled(false)
 
  282        return htConfiguration->GetLdpcSupported();
 
  295        if (htConfiguration->GetShortGuardIntervalSupported())
 
  312        gi = 
static_cast<uint16_t
>(heConfiguration->GetGuardInterval().GetNanoSeconds());
 
  325                                                  bool isShortPreambleSupported)
 
  329    LookupState(address)->m_shortPreamble = isShortPreambleSupported;
 
  334                                                  bool isShortSlotTimeSupported)
 
  338    LookupState(address)->m_shortSlotTime = isShortSlotTimeSupported;
 
  347    for (
const auto& i : state->m_operationalRateSet)
 
  357        state->m_dsssSupported = 
true;
 
  361        state->m_erpOfdmSupported = 
true;
 
  365        state->m_ofdmSupported = 
true;
 
  367    state->m_operationalRateSet.push_back(mode);
 
  376    state->m_operationalRateSet.clear();
 
  379        state->m_operationalRateSet.push_back(mode);
 
  380        if (mode.IsMandatory())
 
  393    state->m_operationalMcsSet.clear();
 
  396        state->m_operationalMcsSet.push_back(mcs);
 
  414    for (
const auto& i : state->m_operationalMcsSet)
 
  421    state->m_operationalMcsSet.push_back(mcs);
 
  445    if (address.IsGroup())
 
  455    if (address.IsGroup())
 
  465    if (address.IsGroup())
 
  503    if (address.IsGroup())
 
  520    std::shared_ptr<WifiRemoteStationState> state;
 
  521    if (!remoteAddress.IsGroup() &&
 
  545            if (staMac->IsAssociated())
 
  547                staId = staMac->GetAssociationId();
 
  574    state->m_mldAddress = mldAddress;
 
  579std::optional<Mac48Address>
 
  580WifiRemoteStationManager::GetMldAddress(
const Mac48Address& address)
 const 
  582    return LookupState(address)->m_mldAddress;
 
  585std::optional<Mac48Address>
 
  586WifiRemoteStationManager::GetAffiliatedStaAddress(
const Mac48Address& mldAddress)
 const 
  588    auto stateIt = m_states.find(mldAddress);
 
  590    if (stateIt == m_states.end() || !stateIt->second->m_mldAddress)
 
  596    NS_ASSERT(*stateIt->second->m_mldAddress == mldAddress);
 
  597    return stateIt->second->m_address;
 
  601WifiRemoteStationManager::GetDataTxVector(
const WifiMacHeader& header, uint16_t allowedWidth)
 
  605    if (!header.
IsMgt() && address.IsGroup())
 
  607        WifiMode mode = GetNonUnicastMode();
 
  615        v.
SetNTx(GetNumberOfAntennas());
 
  625        if (GetNBasicModes() > 0)
 
  627            mgtMode = GetBasicMode(0);
 
  631            mgtMode = GetDefaultMode();
 
  637        uint16_t channelWidth = allowedWidth;
 
  640            if (uint16_t rxWidth = GetChannelWidthSupported(header.
GetAddr1());
 
  641                rxWidth < channelWidth)
 
  643                channelWidth = rxWidth;
 
  647        txVector.
SetChannelWidth(m_wifiPhy->GetTxBandwidth(mgtMode, channelWidth));
 
  653        txVector = DoGetDataTxVector(Lookup(address), allowedWidth);
 
  656                             : UseLdpcForDestination(address));
 
  661        txVector.
SetBssColor(heConfiguration->GetBssColor());
 
  668                                             << 
" MHz) exceeds allowed width (" << allowedWidth
 
  674WifiRemoteStationManager::GetCtsToSelfTxVector()
 
  676    WifiMode defaultMode = GetDefaultMode();
 
  700                        GetDefaultTxPowerLevel(),
 
  703                        GetNumberOfAntennas(),
 
  706                        m_wifiPhy->GetTxBandwidth(defaultMode),
 
  714    if (address.IsGroup())
 
  716        WifiMode mode = GetNonUnicastMode();
 
  724        v.
SetNTx(GetNumberOfAntennas());
 
  729    return DoGetRtsTxVector(Lookup(address));
 
  736    WifiMode ctsMode = GetControlAnswerMode(rtsTxMode);
 
  743    uint16_t ctsTxGuardInterval =
 
  751WifiRemoteStationManager::AdjustTxVectorForIcf(
WifiTxVector& txVector)
 const 
  755    auto txMode = txVector.
GetMode();
 
  763        else if (rate >= 12e6)
 
  774            txVector.
SetMode(ErpOfdmPhy::GetErpOfdmRate(rate));
 
  778            txVector.
SetMode(OfdmPhy::GetOfdmRate(rate));
 
  787    WifiMode ackMode = GetControlAnswerMode(dataTxVector.
GetMode(GetStaId(to, dataTxVector)));
 
  794    uint16_t ackTxGuardInterval =
 
  806    WifiMode blockAckMode = GetControlAnswerMode(dataTxVector.
GetMode(GetStaId(to, dataTxVector)));
 
  813    uint16_t blockAckTxGuardInterval =
 
  821WifiRemoteStationManager::GetControlAnswerMode(
WifiMode reqMode)
 const 
  841    for (uint8_t i = 0; i < GetNBasicModes(); i++)
 
  843        WifiMode testMode = GetBasicMode(i);
 
  855    if (GetHtSupported())
 
  859            mode = GetDefaultMcs();
 
  860            for (uint8_t i = 0; i != GetNBasicMcs(); i++)
 
  880        NS_LOG_DEBUG(
"WifiRemoteStationManager::GetControlAnswerMode returning " << mode);
 
  901    for (
const auto& thismode : m_wifiPhy->GetModeList())
 
  912        if (thismode.IsMandatory() && (!found || thismode.IsHigherDataRate(mode)) &&
 
  913            (!thismode.IsHigherDataRate(reqMode)) &&
 
  915                                                   thismode.GetModulationClass())))
 
  924    if (GetHtSupported())
 
  926        for (
const auto& thismode : m_wifiPhy->GetMcsList())
 
  928            if (thismode.IsMandatory() && (!found || thismode.IsHigherDataRate(mode)) &&
 
  929                (!thismode.IsHigherCodeRate(reqMode)) &&
 
  955    NS_LOG_DEBUG(
"WifiRemoteStationManager::GetControlAnswerMode returning " << mode);
 
  966    m_macTxRtsFailed(header.
GetAddr1());
 
  967    DoReportRtsFailed(Lookup(header.
GetAddr1()));
 
  974    NS_ASSERT(!mpdu->GetHeader().GetAddr1().IsGroup());
 
  976        QosUtilsMapTidToAc((mpdu->GetHeader().IsQosData()) ? mpdu->GetHeader().GetQosTid() : 0);
 
  977    bool longMpdu = (mpdu->GetSize() > m_rtsCtsThreshold);
 
  986    m_macTxDataFailed(mpdu->GetHeader().GetAddr1());
 
  987    DoReportDataFailed(Lookup(mpdu->GetHeader().GetAddr1()));
 
 1002    DoReportRtsOk(station, ctsSnr, ctsMode, rtsSnr);
 
 1012    NS_LOG_FUNCTION(
this << *mpdu << ackSnr << ackMode << dataSnr << dataTxVector);
 
 1017    bool longMpdu = (mpdu->GetSize() > m_rtsCtsThreshold);
 
 1028    DoReportDataOk(station,
 
 1045    m_macTxFinalRtsFailed(header.
GetAddr1());
 
 1046    DoReportFinalRtsFailed(station);
 
 1053    NS_ASSERT(!mpdu->GetHeader().GetAddr1().IsGroup());
 
 1056        QosUtilsMapTidToAc((mpdu->GetHeader().IsQosData()) ? mpdu->GetHeader().GetQosTid() : 0);
 
 1058    bool longMpdu = (mpdu->GetSize() > m_rtsCtsThreshold);
 
 1067    m_macTxFinalDataFailed(mpdu->GetHeader().GetAddr1());
 
 1068    DoReportFinalDataFailed(station);
 
 1077    if (address.IsGroup())
 
 1082    DoReportRxOk(station, rxSignalInfo.
snr, txVector.
GetMode(GetStaId(address, txVector)));
 
 1088                                              uint16_t nSuccessfulMpdus,
 
 1089                                              uint16_t nFailedMpdus,
 
 1094    NS_LOG_FUNCTION(
this << address << nSuccessfulMpdus << nFailedMpdus << rxSnr << dataSnr
 
 1097    for (uint16_t i = 0; i < nFailedMpdus; i++)
 
 1099        m_macTxDataFailed(address);
 
 1101    DoReportAmpduTxStatus(Lookup(address),
 
 1107                          dataTxVector.
GetNss(GetStaId(address, dataTxVector)));
 
 1115    WifiTxVector txVector = GetDataTxVector(header, m_wifiPhy->GetChannelWidth());
 
 1117    if (address.IsGroup())
 
 1121    if (m_erpProtectionMode == RTS_CTS &&
 
 1125        m_useNonErpProtection)
 
 1128            "WifiRemoteStationManager::NeedRTS returning true to protect non-ERP stations");
 
 1131    else if (m_htProtectionMode == RTS_CTS &&
 
 1133             m_useNonHtProtection && !(m_erpProtectionMode != RTS_CTS && m_useNonErpProtection))
 
 1135        NS_LOG_DEBUG(
"WifiRemoteStationManager::NeedRTS returning true to protect non-HT stations");
 
 1138    bool normally = (size > m_rtsCtsThreshold);
 
 1139    return DoNeedRts(Lookup(address), size, normally);
 
 1147    if (m_erpProtectionMode == CTS_TO_SELF &&
 
 1153        m_useNonErpProtection)
 
 1156            "WifiRemoteStationManager::NeedCtsToSelf returning true to protect non-ERP stations");
 
 1159    else if (m_htProtectionMode == CTS_TO_SELF &&
 
 1162             m_useNonHtProtection && !(m_erpProtectionMode != CTS_TO_SELF && m_useNonErpProtection))
 
 1165            "WifiRemoteStationManager::NeedCtsToSelf returning true to protect non-HT stations");
 
 1168    else if (!m_useNonErpProtection)
 
 1176                NS_LOG_DEBUG(
"WifiRemoteStationManager::NeedCtsToSelf returning false");
 
 1180        if (GetHtSupported())
 
 1189                    NS_LOG_DEBUG(
"WifiRemoteStationManager::NeedCtsToSelf returning false");
 
 1194        NS_LOG_DEBUG(
"WifiRemoteStationManager::NeedCtsToSelf returning true");
 
 1201WifiRemoteStationManager::SetUseNonErpProtection(
bool enable)
 
 1204    m_useNonErpProtection = enable;
 
 1208WifiRemoteStationManager::GetUseNonErpProtection()
 const 
 1210    return m_useNonErpProtection;
 
 1214WifiRemoteStationManager::SetUseNonHtProtection(
bool enable)
 
 1217    m_useNonHtProtection = enable;
 
 1221WifiRemoteStationManager::GetUseNonHtProtection()
 const 
 1223    return m_useNonHtProtection;
 
 1230    NS_ASSERT(!mpdu->GetHeader().GetAddr1().IsGroup());
 
 1232        QosUtilsMapTidToAc((mpdu->GetHeader().IsQosData()) ? mpdu->GetHeader().GetQosTid() : 0);
 
 1233    bool longMpdu = (mpdu->GetSize() > m_rtsCtsThreshold);
 
 1238        retryCount = m_slrc[ac];
 
 1239        maxRetryCount = m_maxSlrc;
 
 1243        retryCount = m_ssrc[ac];
 
 1244        maxRetryCount = m_maxSsrc;
 
 1246    bool normally = retryCount < maxRetryCount;
 
 1247    NS_LOG_DEBUG(
"WifiRemoteStationManager::NeedRetransmission count: " 
 1248                 << retryCount << 
" result: " << std::boolalpha << normally);
 
 1249    return DoNeedRetransmission(Lookup(mpdu->GetHeader().GetAddr1()), mpdu->GetPacket(), normally);
 
 1256    if (mpdu->GetHeader().GetAddr1().IsGroup())
 
 1260    bool normally = mpdu->GetSize() > GetFragmentationThreshold();
 
 1261    NS_LOG_DEBUG(
"WifiRemoteStationManager::NeedFragmentation result: " << std::boolalpha
 
 1263    return DoNeedFragmentation(Lookup(mpdu->GetHeader().GetAddr1()), mpdu->GetPacket(), normally);
 
 1267WifiRemoteStationManager::DoSetFragmentationThreshold(
uint32_t threshold)
 
 1270    if (threshold < 256)
 
 1275        NS_LOG_WARN(
"Fragmentation threshold should be larger than 256. Setting to 256.");
 
 1276        m_fragmentationThreshold = 256;
 
 1284        if (threshold % 2 != 0)
 
 1286            NS_LOG_WARN(
"Fragmentation threshold should be an even number. Setting to " 
 1288            m_fragmentationThreshold = threshold - 1;
 
 1292            m_fragmentationThreshold = threshold;
 
 1298WifiRemoteStationManager::DoGetFragmentationThreshold()
 const 
 1300    return m_fragmentationThreshold;
 
 1309        (mpdu->GetPacket()->GetSize() /
 
 1310         (GetFragmentationThreshold() - mpdu->GetHeader().GetSize() - WIFI_MAC_FCS_LENGTH));
 
 1313    if ((mpdu->GetPacket()->GetSize() %
 
 1314         (GetFragmentationThreshold() - mpdu->GetHeader().GetSize() - WIFI_MAC_FCS_LENGTH)) > 0)
 
 1318    NS_LOG_DEBUG(
"WifiRemoteStationManager::GetNFragments returning " << nFragments);
 
 1326    NS_ASSERT(!mpdu->GetHeader().GetAddr1().IsGroup());
 
 1327    uint32_t nFragment = GetNFragments(mpdu);
 
 1328    if (fragmentNumber >= nFragment)
 
 1330        NS_LOG_DEBUG(
"WifiRemoteStationManager::GetFragmentSize returning 0");
 
 1334    if (fragmentNumber == nFragment - 1)
 
 1337            mpdu->GetPacket()->GetSize() -
 
 1339             (GetFragmentationThreshold() - mpdu->GetHeader().GetSize() - WIFI_MAC_FCS_LENGTH));
 
 1340        NS_LOG_DEBUG(
"WifiRemoteStationManager::GetFragmentSize returning " << lastFragmentSize);
 
 1341        return lastFragmentSize;
 
 1347            GetFragmentationThreshold() - mpdu->GetHeader().GetSize() - WIFI_MAC_FCS_LENGTH;
 
 1348        NS_LOG_DEBUG(
"WifiRemoteStationManager::GetFragmentSize returning " << fragmentSize);
 
 1349        return fragmentSize;
 
 1357    NS_ASSERT(!mpdu->GetHeader().GetAddr1().IsGroup());
 
 1358    NS_ASSERT(fragmentNumber < GetNFragments(mpdu));
 
 1359    uint32_t fragmentOffset = fragmentNumber * (GetFragmentationThreshold() -
 
 1360                                                mpdu->GetHeader().GetSize() - WIFI_MAC_FCS_LENGTH);
 
 1361    NS_LOG_DEBUG(
"WifiRemoteStationManager::GetFragmentOffset returning " << fragmentOffset);
 
 1362    return fragmentOffset;
 
 1369    NS_ASSERT(!mpdu->GetHeader().GetAddr1().IsGroup());
 
 1370    bool isLast = fragmentNumber == (GetNFragments(mpdu) - 1);
 
 1371    NS_LOG_DEBUG(
"WifiRemoteStationManager::IsLastFragment returning " << std::boolalpha << isLast);
 
 1376WifiRemoteStationManager::GetDefaultTxPowerLevel()
 const 
 1378    return m_defaultTxPowerLevel;
 
 1384    return LookupState(address)->m_info;
 
 1387std::optional<double>
 
 1390    auto station = Lookup(address);
 
 1391    auto rssi = station->m_rssiAndUpdateTimePair.first;
 
 1392    auto ts = station->m_rssiAndUpdateTimePair.second;
 
 1393    if (ts.IsStrictlyPositive())
 
 1397    return std::nullopt;
 
 1400std::shared_ptr<WifiRemoteStationState>
 
 1404    auto stateIt = m_states.find(address);
 
 1406    if (stateIt != m_states.end())
 
 1408        NS_LOG_DEBUG(
"WifiRemoteStationManager::LookupState returning existing state");
 
 1409        return stateIt->second;
 
 1412    auto state = std::make_shared<WifiRemoteStationState>();
 
 1413    state->m_state = WifiRemoteStationState::BRAND_NEW;
 
 1414    state->m_address = address;
 
 1416    state->m_operationalRateSet.push_back(GetDefaultMode());
 
 1417    state->m_operationalMcsSet.push_back(GetDefaultMcs());
 
 1418    state->m_dsssSupported = 
false;
 
 1419    state->m_erpOfdmSupported = 
false;
 
 1420    state->m_ofdmSupported = 
false;
 
 1421    state->m_htCapabilities = 
nullptr;
 
 1422    state->m_vhtCapabilities = 
nullptr;
 
 1423    state->m_heCapabilities = 
nullptr;
 
 1424    state->m_ehtCapabilities = 
nullptr;
 
 1425    state->m_emlCapabilities = 
nullptr;
 
 1426    state->m_emlsrEnabled = 
false;
 
 1427    state->m_channelWidth = m_wifiPhy->GetChannelWidth();
 
 1428    state->m_guardInterval = GetGuardInterval();
 
 1430    state->m_aggregation = 
false;
 
 1431    state->m_qosSupported = 
false;
 
 1432    state->m_isInPsMode = 
false;
 
 1434    NS_LOG_DEBUG(
"WifiRemoteStationManager::LookupState returning new state");
 
 1442    auto stationIt = m_stations.find(address);
 
 1444    if (stationIt != m_stations.end())
 
 1446        return stationIt->second;
 
 1450    station->
m_state = LookupState(address).get();
 
 1457WifiRemoteStationManager::SetAssociationId(
Mac48Address remoteAddress, uint16_t aid)
 
 1460    LookupState(remoteAddress)->m_aid = aid;
 
 1464WifiRemoteStationManager::SetQosSupport(
Mac48Address from, 
bool qosSupported)
 
 1467    LookupState(from)->m_qosSupported = qosSupported;
 
 1471WifiRemoteStationManager::SetEmlsrEnabled(
const Mac48Address& from, 
bool emlsrEnabled)
 
 1474    LookupState(from)->m_emlsrEnabled = emlsrEnabled;
 
 1482    auto state = LookupState(from);
 
 1485        state->m_channelWidth = 40;
 
 1489        state->m_channelWidth = 20;
 
 1491    SetQosSupport(from, 
true);
 
 1496            AddSupportedMcs(from, mcs);
 
 1499    state->m_htCapabilities = Create<const HtCapabilities>(htCapabilities);
 
 1508    auto state = LookupState(from);
 
 1511        state->m_channelWidth = 160;
 
 1515        state->m_channelWidth = 80;
 
 1517    for (uint8_t i = 1; i <= m_wifiPhy->GetMaxSupportedTxSpatialStreams(); i++)
 
 1523                AddSupportedMcs(from, mcs);
 
 1527    state->m_vhtCapabilities = Create<const VhtCapabilities>(vhtCapabilities);
 
 1535    auto state = LookupState(from);
 
 1541            state->m_channelWidth = 160;
 
 1545            state->m_channelWidth = 80;
 
 1553            state->m_channelWidth = 40;
 
 1557            state->m_channelWidth = 20;
 
 1562        state->m_guardInterval = 800;
 
 1567        state->m_guardInterval = 3200;
 
 1573            AddSupportedMcs(from, mcs);
 
 1576    state->m_heCapabilities = Create<const HeCapabilities>(heCapabilities);
 
 1577    SetQosSupport(from, 
true);
 
 1586    auto state = LookupState(from);
 
 1589        for (uint8_t mapType = 0; mapType < EhtMcsAndNssSet::EHT_MCS_MAP_TYPE_MAX; ++mapType)
 
 1594                AddSupportedMcs(from, mcs);
 
 1598    state->m_ehtCapabilities = Create<const EhtCapabilities>(ehtCapabilities);
 
 1599    SetQosSupport(from, 
true);
 
 1603WifiRemoteStationManager::AddStationEmlCapabilities(
 
 1605    const std::shared_ptr<CommonInfoBasicMle::EmlCapabilities>& emlCapabilities)
 
 1608    LookupState(from)->m_emlCapabilities = emlCapabilities;
 
 1614    return LookupState(from)->m_htCapabilities;
 
 1620    return LookupState(from)->m_vhtCapabilities;
 
 1626    return LookupState(from)->m_heCapabilities;
 
 1632    return LookupState(from)->m_ehtCapabilities;
 
 1635std::shared_ptr<CommonInfoBasicMle::EmlCapabilities>
 
 1636WifiRemoteStationManager::GetStationEmlCapabilities(
const Mac48Address& from)
 
 1638    return LookupState(from)->m_emlCapabilities;
 
 1647    bool supported = 
false;
 
 1650        supported |= htCapabilities->GetLdpc();
 
 1652    if (vhtCapabilities)
 
 1654        supported |= vhtCapabilities->GetRxLdpc();
 
 1658        supported |= heCapabilities->GetLdpcCodingInPayload();
 
 1664WifiRemoteStationManager::GetDefaultMode()
 const 
 1666    return m_defaultTxMode;
 
 1670WifiRemoteStationManager::GetDefaultMcs()
 const 
 1672    return m_defaultTxMcs;
 
 1680    if (!GetHtSupported() || !GetHtSupported(st))
 
 1682        return GetDefaultMode();
 
 1687    if (GetHeSupported() && GetHeSupported(st))
 
 1691    else if (GetVhtSupported() && GetVhtSupported(st))
 
 1697    return *m_wifiPhy->GetPhyEntity(modClass)->begin();
 
 1701WifiRemoteStationManager::Reset()
 
 1705    for (
auto& state : m_stations)
 
 1707        delete (state.second);
 
 1710    m_bssBasicRateSet.clear();
 
 1711    m_bssBasicMcsSet.clear();
 
 1722        NS_FATAL_ERROR(
"It is not allowed to add a HT rate in the BSSBasicRateSet!");
 
 1724    for (uint8_t i = 0; i < GetNBasicModes(); i++)
 
 1726        if (GetBasicMode(i) == mode)
 
 1731    m_bssBasicRateSet.push_back(mode);
 
 1735WifiRemoteStationManager::GetNBasicModes()
 const 
 1737    return static_cast<uint8_t
>(m_bssBasicRateSet.size());
 
 1741WifiRemoteStationManager::GetBasicMode(uint8_t i)
 const 
 1744    return m_bssBasicRateSet[i];
 
 1748WifiRemoteStationManager::GetNNonErpBasicModes()
 const 
 1763WifiRemoteStationManager::GetNonErpBasicMode(uint8_t i)
 const 
 1784    return m_bssBasicRateSet[index];
 
 1791    for (uint8_t i = 0; i < GetNBasicMcs(); i++)
 
 1793        if (GetBasicMcs(i) == mcs)
 
 1798    m_bssBasicMcsSet.push_back(mcs);
 
 1802WifiRemoteStationManager::GetNBasicMcs()
 const 
 1804    return static_cast<uint8_t
>(m_bssBasicMcsSet.size());
 
 1808WifiRemoteStationManager::GetBasicMcs(uint8_t i)
 const 
 1811    return m_bssBasicMcsSet[i];
 
 1815WifiRemoteStationManager::GetNonUnicastMode()
 const 
 1817    if (m_nonUnicastMode == 
WifiMode())
 
 1819        if (GetNBasicModes() > 0)
 
 1821            return GetBasicMode(0);
 
 1825            return GetDefaultMode();
 
 1830        return m_nonUnicastMode;
 
 1858                                                uint16_t nSuccessfulMpdus,
 
 1859                                                uint16_t nFailedMpdus,
 
 1862                                                uint16_t dataChannelWidth,
 
 1865    NS_LOG_DEBUG(
"DoReportAmpduTxStatus received but the manager does not handle A-MPDUs!");
 
 1878    NS_ASSERT(i < GetNMcsSupported(station));
 
 1885    NS_ASSERT(i < GetNNonErpSupported(station));
 
 1929    if (!htCapabilities)
 
 1933    return htCapabilities->GetShortGuardInterval20();
 
 1953    if (!htCapabilities)
 
 1957    return htCapabilities->GetRxHighestSupportedAntennas();
 
 1967WifiRemoteStationManager::GetPhy()
 const 
 1973WifiRemoteStationManager::GetMac()
 const 
 2018    return emlCapabilities && emlCapabilities->emlsrSupport == 1;
 
 2051WifiRemoteStationManager::GetChannelWidthSupported(
Mac48Address address)
 const 
 2053    return LookupState(address)->m_channelWidth;
 
 2057WifiRemoteStationManager::GetShortGuardIntervalSupported(
Mac48Address address)
 const 
 2061    if (!htCapabilities)
 
 2065    return htCapabilities->GetShortGuardInterval20();
 
 2069WifiRemoteStationManager::GetNumberOfSupportedStreams(
Mac48Address address)
 const 
 2073    if (!htCapabilities)
 
 2077    return htCapabilities->GetRxHighestSupportedAntennas();
 
 2083    return static_cast<uint8_t
>(LookupState(address)->m_operationalMcsSet.size());
 
 2087WifiRemoteStationManager::GetDsssSupported(
const Mac48Address& address)
 const 
 2089    return (LookupState(address)->m_dsssSupported);
 
 2093WifiRemoteStationManager::GetErpOfdmSupported(
const Mac48Address& address)
 const 
 2095    return (LookupState(address)->m_erpOfdmSupported);
 
 2099WifiRemoteStationManager::GetOfdmSupported(
const Mac48Address& address)
 const 
 2101    return (LookupState(address)->m_ofdmSupported);
 
 2107    return bool(LookupState(address)->m_htCapabilities);
 
 2113    return bool(LookupState(address)->m_vhtCapabilities);
 
 2119    return bool(LookupState(address)->m_heCapabilities);
 
 2125    return (
bool)(LookupState(address)->m_ehtCapabilities);
 
 2129WifiRemoteStationManager::GetEmlsrSupported(
const Mac48Address& address)
 const 
 2131    auto emlCapabilities = LookupState(address)->m_emlCapabilities;
 
 2132    return emlCapabilities && emlCapabilities->emlsrSupport == 1;
 
 2136WifiRemoteStationManager::GetEmlsrEnabled(
const Mac48Address& address)
 const 
 2138    if (
auto stateIt = m_states.find(address); stateIt != m_states.cend())
 
 2140        return stateIt->second->m_emlsrEnabled;
 
 2146WifiRemoteStationManager::SetDefaultTxPowerLevel(uint8_t txPower)
 
 2148    m_defaultTxPowerLevel = txPower;
 
 2152WifiRemoteStationManager::GetNumberOfAntennas()
 const 
 2154    return m_wifiPhy->GetNumberOfAntennas();
 
 2158WifiRemoteStationManager::GetMaxNumberOfTransmitStreams()
 const 
 2160    return m_wifiPhy->GetMaxSupportedTxSpatialStreams();
 
 2166    return (GetLdpcSupported() && GetLdpcSupported(dest));
 
The IEEE 802.11be EHT Capabilities.
uint8_t GetHighestSupportedRxMcs(EhtMcsAndNssSet::EhtMcsMapType mapType)
Get the highest supported RX MCS for a given EHT-MCS map type.
Hold variables of type enum.
The IEEE 802.11ax HE Capabilities.
uint8_t GetHighestMcsSupported() const
Get highest MCS supported.
bool GetHeSuPpdu1xHeLtf800nsGi() const
Get 1xHE-LTF and 800ns GI in HE SU PPDU reception support.
uint8_t GetChannelWidthSet() const
Get channel width set.
The HT Capabilities Information Element.
uint8_t GetSupportedChannelWidth() const
Return the supported channel width.
bool IsSupportedMcs(uint8_t mcs) const
Return the is MCS supported flag.
static WifiMode GetHtMcs(uint8_t index)
Return the HT MCS corresponding to the provided index.
A base class which provides memory management and object aggregation.
Smart pointer class similar to boost::intrusive_ptr.
a unique identifier for an interface.
TypeId SetParent(TypeId tid)
Set the parent TypeId.
Hold an unsigned integer type.
The IEEE 802.11ac VHT Capabilities.
bool IsSupportedMcs(uint8_t mcs, uint8_t nss) const
Get the is MCS supported.
uint8_t GetSupportedChannelWidthSet() const
Get the supported channel width set.
TypeOfStation GetTypeOfStation() const
Return the type of station.
represent a single transmission mode
bool IsHigherDataRate(WifiMode mode) const
WifiModulationClass GetModulationClass() const
uint64_t GetDataRate(uint16_t channelWidth, uint16_t guardInterval, uint8_t nss) const
uint8_t GetMcsValue() const
AttributeValue implementation for WifiMode.
Ptr< VhtConfiguration > GetVhtConfiguration() const
Ptr< EhtConfiguration > GetEhtConfiguration() const
Ptr< HtConfiguration > GetHtConfiguration() const
Ptr< HeConfiguration > GetHeConfiguration() const
WifiPhyBand GetPhyBand() const
Get the configured Wi-Fi band.
Ptr< WifiNetDevice > GetDevice() const
Return the device this PHY is associated with.
std::list< WifiMode > GetMcsList() const
The WifiPhy::GetMcsList() method is used (e.g., by a WifiRemoteStationManager) to determine the set o...
std::list< WifiMode > GetModeList() const
The WifiPhy::GetModeList() method is used (e.g., by a WifiRemoteStationManager) to determine the set ...
TID independent remote station statistics.
void NotifyTxSuccess(uint32_t retryCounter)
Updates average frame error rate when data or RTS was transmitted successfully.
void NotifyTxFailed()
Updates average frame error rate when final data or RTS has failed.
hold a list of per-remote-station state.
bool GetQosSupported(Mac48Address address) const
Return whether the given station is QoS capable.
void SetShortSlotTimeEnabled(bool enable)
Enable or disable short slot time.
void SetPsMode(const Mac48Address &address, bool isInPsMode)
Register whether the STA is in Power Save mode or not.
void AddBasicMode(WifiMode mode)
Invoked in a STA upon association to store the set of rates which belong to the BSSBasicRateSet of th...
virtual int64_t AssignStreams(int64_t stream)
Assign a fixed random variable stream number to the random variables used by this model.
uint16_t GetAssociationId(Mac48Address remoteAddress) const
Get the AID of a remote station.
WifiMode m_defaultTxMcs
The default transmission modulation-coding scheme (MCS)
ProtectionMode m_htProtectionMode
Protection mode for HT stations when non-HT stations are detected.
uint32_t GetFragmentationThreshold() const
Return the fragmentation threshold.
uint32_t m_maxSsrc
Maximum STA short retry count (SSRC)
void SetRtsCtsThreshold(uint32_t threshold)
Sets the RTS threshold.
void AddAllSupportedMcs(Mac48Address address)
Invoked in a STA or AP to store all of the MCS supported by a destination which is also supported loc...
TracedCallback< Mac48Address > m_macTxRtsFailed
The trace source fired when the transmission of a single RTS has failed.
void DoSetFragmentationThreshold(uint32_t threshold)
Actually sets the fragmentation threshold, it also checks the validity of the given threshold.
bool IsBrandNew(Mac48Address address) const
Return whether the station state is brand new.
bool GetShortSlotTimeEnabled() const
Return whether the device uses short slot time.
void DoDispose() override
Destructor implementation.
~WifiRemoteStationManager() override
bool GetShortPreambleSupported(Mac48Address address) const
Return whether the station supports short PHY preamble or not.
void AddAllSupportedModes(Mac48Address address)
Invoked in a STA or AP to store all of the modes supported by a destination which is also supported l...
void AddSupportedMcs(Mac48Address address, WifiMode mcs)
Record the MCS index supported by the station.
void RemoveAllSupportedMcs(Mac48Address address)
Invoked in a STA or AP to delete all of the supported MCS by a destination.
uint32_t DoGetFragmentationThreshold() const
Return the current fragmentation threshold.
TracedCallback< Mac48Address > m_macTxFinalRtsFailed
The trace source fired when the transmission of a RTS has exceeded the maximum number of attempts.
bool m_shortPreambleEnabled
flag if short PHY preamble is enabled
bool GetShortSlotTimeSupported(Mac48Address address) const
Return whether the station supports short ERP slot time or not.
void SetShortPreambleEnabled(bool enable)
Enable or disable short PHY preambles.
Ptr< WifiPhy > m_wifiPhy
This is a pointer to the WifiPhy associated with this WifiRemoteStationManager that is set on call to...
uint8_t m_defaultTxPowerLevel
Default transmission power level.
static TypeId GetTypeId()
Get the type ID.
WifiMode m_nonUnicastMode
Transmission mode for non-unicast Data frames.
uint16_t GetGuardInterval() const
Return the supported HE guard interval duration (in nanoseconds).
bool IsAssociated(Mac48Address address) const
Return whether the station associated.
WifiRemoteStationManager()
bool GetHtSupported() const
Return whether the device has HT capability support enabled.
void RecordWaitAssocTxOk(Mac48Address address)
Records that we are waiting for an ACK for the association response we sent.
void SetFragmentationThreshold(uint32_t threshold)
Sets a fragmentation threshold.
Ptr< WifiMac > m_wifiMac
This is a pointer to the WifiMac associated with this WifiRemoteStationManager that is set on call to...
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.
bool GetLdpcSupported() const
Return whether the device has LDPC support enabled.
bool GetEhtSupported() const
Return whether the device has EHT capability support enabled.
void AddSupportedMode(Mac48Address address, WifiMode mode)
Invoked in a STA or AP to store the set of modes supported by a destination which is also supported l...
std::shared_ptr< WifiRemoteStationState > LookupState(Mac48Address address) const
Return the state of the station associated with the given address.
void RecordAssocRefused(Mac48Address address)
Records that association request was refused.
bool IsInPsMode(const Mac48Address &address) const
Return whether the STA is currently in Power Save mode.
StationStates m_states
States of known stations.
void SetMaxSsrc(uint32_t maxSsrc)
Sets the maximum STA short retry count (SSRC).
TracedCallback< Mac48Address > m_macTxDataFailed
The trace source fired when the transmission of a single data packet has failed.
uint16_t GetStaId(Mac48Address address, const WifiTxVector &txVector) const
If the given TXVECTOR is used for a MU transmission, return the STAID of the station with the given a...
void AddSupportedPhyPreamble(Mac48Address address, bool isShortPreambleSupported)
Record whether the short PHY preamble is supported by the station.
bool GetShortGuardIntervalSupported() const
Return whether the device has SGI support enabled.
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...
void RecordDisassociated(Mac48Address address)
Records that the STA was disassociated.
uint32_t m_maxSlrc
Maximum STA long retry count (SLRC)
void Reset()
Reset the station, invoked in a STA upon dis-association or in an AP upon reboot.
bool IsAssocRefused(Mac48Address address) const
Return whether we refused an association request from the given station.
bool GetVhtSupported() const
Return whether the device has VHT capability support enabled.
ProtectionMode m_erpProtectionMode
Protection mode for ERP stations when non-ERP stations are detected.
void AddSupportedErpSlotTime(Mac48Address address, bool isShortSlotTimeSupported)
Record whether the short ERP slot time is supported by the station.
bool GetShortPreambleEnabled() const
Return whether the device uses short PHY preambles.
bool GetHeSupported() const
Return whether the device has HE capability support enabled.
WifiMode m_defaultTxMode
The default transmission mode.
void RecordGotAssocTxFailed(Mac48Address address)
Records that we missed an ACK for the association response we sent.
virtual void SetupMac(const Ptr< WifiMac > mac)
Set up MAC associated with this device since it is the object that knows the full set of timing param...
uint32_t m_rtsCtsThreshold
Threshold for RTS/CTS.
bool m_shortSlotTimeEnabled
flag if short slot time is enabled
bool IsWaitAssocTxOk(Mac48Address address) const
Return whether we are waiting for an ACK for the association response we sent.
void SetMaxSlrc(uint32_t maxSlrc)
Sets the maximum STA long retry count (SLRC).
TracedCallback< Mac48Address > m_macTxFinalDataFailed
The trace source fired when the transmission of a data packet has exceeded the maximum number of atte...
This class mimics the TXVECTOR which is to be passed to the PHY in order to define the parameters whi...
void SetNess(uint8_t ness)
Sets the Ness number.
void SetTxPowerLevel(uint8_t powerlevel)
Sets the selected transmission power level.
void SetLdpc(bool ldpc)
Sets if LDPC FEC coding is being used.
void SetChannelWidth(uint16_t channelWidth)
Sets the selected channelWidth (in MHz)
void SetGuardInterval(uint16_t guardInterval)
Sets the guard interval duration (in nanoseconds)
WifiMode GetMode(uint16_t staId=SU_STA_ID) const
If this TX vector is associated with an SU PPDU, return the selected payload transmission mode.
WifiModulationClass GetModulationClass() const
Get the modulation class specified by this TXVECTOR.
uint8_t GetNss(uint16_t staId=SU_STA_ID) const
If this TX vector is associated with an SU PPDU, return the number of spatial streams.
void SetBssColor(uint8_t color)
Set the BSS color.
void SetNTx(uint8_t nTx)
Sets the number of TX antennas.
uint16_t GetChannelWidth() const
void SetMode(WifiMode mode)
Sets the selected payload transmission mode.
void SetNss(uint8_t nss)
Sets the number of Nss.
void SetPreambleType(WifiPreamble preamble)
Sets the preamble type.
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file,...
#define NS_ASSERT_MSG(condition, message)
At runtime, in debugging builds, if this condition is not true, the program prints the message to out...
Ptr< const AttributeAccessor > MakeEnumAccessor(T1 a1)
Ptr< const AttributeAccessor > MakeUintegerAccessor(T1 a1)
#define NS_FATAL_ERROR(msg)
Report a fatal error with a message and terminate.
#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_LOG_WARN(msg)
Use NS_LOG to output a message of level LOG_WARN.
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system.
Time Seconds(double 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.
AcIndex QosUtilsMapTidToAc(uint8_t tid)
Maps TID (Traffic ID) to Access classes.
WifiPreamble
The type of preamble to be used by an IEEE 802.11 transmission.
WifiModulationClass
This enumeration defines the modulation classes per (Table 10-6 "Modulation classes"; IEEE 802....
AcIndex
This enumeration defines the Access Categories as an enumeration with values corresponding to the AC ...
@ WIFI_PHY_BAND_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_OFDM
OFDM (Clause 17)
@ 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)
@ WIFI_MOD_CLASS_DSSS
DSSS (Clause 15)
@ WIFI_MOD_CLASS_ERP_OFDM
ERP-OFDM (18.4)
Every class exported by the ns3 library is enclosed in the ns3 namespace.
bool IsAllowedControlAnswerModulationClass(WifiModulationClass modClassReq, WifiModulationClass modClassAnswer)
Return whether the modulation class of the selected mode for the control answer frame is allowed.
WifiModeList::const_iterator WifiModeListIterator
An iterator for WifiModeList vector.
uint16_t ConvertGuardIntervalToNanoSeconds(WifiMode mode, const Ptr< WifiNetDevice > device)
Convert the guard interval to nanoseconds based on the WifiMode.
WifiPreamble GetPreambleForTransmission(WifiModulationClass modulation, bool useShortPreamble)
Return the preamble to be used for the transmission.
static constexpr uint16_t SU_STA_ID
STA_ID to identify a single user (SU)
Ptr< const AttributeChecker > MakeEnumChecker(int v, std::string n, Ts... args)
Make an EnumChecker pre-configured with a set of allowed values by name.
EhtMcsMapType
The different EHT-MCS map types as defined in 9.4.2.313.4 Supported EHT-MCS And NSS Set field.
RxSignalInfo structure containing info on the received signal.
double snr
SNR in linear scale.
hold per-remote-station state.
WifiRemoteStationState * m_state
Remote station state.
std::pair< double, Time > m_rssiAndUpdateTimePair
RSSI (in dBm) of the most recent packet received from the remote station along with update time.
Mac48Address m_address
Mac48Address of the remote station.
uint16_t m_channelWidth
Channel width (in MHz) supported by the remote station.
uint8_t m_ness
Number of extended spatial streams of the remote station.
bool m_aggregation
Flag if MPDU aggregation is used by the remote station.
bool m_qosSupported
Flag if QoS is supported by the station.
WifiModeList m_operationalRateSet
This member is the list of WifiMode objects that comprise the OperationalRateSet parameter for this r...
WifiModeList m_operationalMcsSet
operational MCS set
uint16_t m_guardInterval
HE Guard interval duration (in nanoseconds) supported by the remote station.
Ptr< const EhtCapabilities > m_ehtCapabilities
remote station EHT capabilities
Ptr< const VhtCapabilities > m_vhtCapabilities
remote station VHT capabilities
WifiRemoteStationInfo m_info
remote station info
bool m_emlsrEnabled
whether EMLSR mode is enabled on this link
Ptr< const HtCapabilities > m_htCapabilities
remote station HT capabilities
Ptr< const HeCapabilities > m_heCapabilities
remote station HE capabilities
std::shared_ptr< CommonInfoBasicMle::EmlCapabilities > m_emlCapabilities
remote station EML capabilities