Check UL OFDMA operations with EMLSR clients. More...
#include "wifi-emlsr-basic-exchanges-test.h"
 Inheritance diagram for EmlsrUlOfdmaTest:
 Inheritance diagram for EmlsrUlOfdmaTest: Collaboration diagram for EmlsrUlOfdmaTest:
 Collaboration diagram for EmlsrUlOfdmaTest:| Public Member Functions | |
| EmlsrUlOfdmaTest (bool enableBsrp, bool protectSingleExchange) | |
| Constructor. | |
|  Public Member Functions inherited from EmlsrOperationsTestBase | |
| EmlsrOperationsTestBase (const std::string &name) | |
| Constructor. | |
| ~EmlsrOperationsTestBase () override=default | |
|  Public Member Functions inherited from ns3::TestCase | |
| TestCase (const TestCase &)=delete | |
| virtual | ~TestCase () | 
| Destructor. | |
| std::string | GetName () const | 
| TestCase & | operator= (const TestCase &)=delete | 
| Protected Member Functions | |
| void | CheckResults () | 
| Check that the simulation produced the expected results. | |
| void | DoRun () override | 
| Implementation to actually run this TestCase. | |
| void | DoSetup () override | 
| Implementation to do any local setup required for this TestCase. | |
| void | Transmit (Ptr< WifiMac > mac, uint8_t phyId, WifiConstPsduMap psduMap, WifiTxVector txVector, double txPowerW) override | 
| Callback invoked when a FEM passes PSDUs to the PHY. | |
|  Protected Member Functions inherited from EmlsrOperationsTestBase | |
| void | CheckAuxPhysSleepMode (Ptr< StaWifiMac > staMac, bool sleep) | 
| Check whether aux PHYs of the given device are in sleep mode/awake. | |
| void | CheckBlockedLink (Ptr< WifiMac > mac, Mac48Address dest, uint8_t linkId, WifiQueueBlockedReason reason, bool blocked, std::string description, bool testUnblockedForOtherReasons=true) | 
| Check whether QoS data unicast transmissions addressed to the given destination on the given link are blocked or unblocked for the given reason on the given device. | |
| void | CheckMainPhyTraceInfo (std::size_t index, std::string_view reason, const std::optional< uint8_t > &fromLinkId, uint8_t toLinkId, bool checkFromLinkId=true, bool checkToLinkId=true) | 
| Check information provided by the EMLSR Manager MainPhySwitch trace. | |
| void | CheckMsdTimerRunning (Ptr< StaWifiMac > staMac, uint8_t linkId, bool isRunning, const std::string &msg) | 
| Check whether the MediumSyncDelay timer is running on the given link of the given device. | |
| Ptr< PacketSocketClient > | GetApplication (TrafficDirection dir, std::size_t staId, std::size_t count, std::size_t pktSize, uint8_t priority=0) const | 
| virtual void | MainPhySwitchInfoCallback (std::size_t index, const EmlsrMainPhySwitchTrace &info) | 
| Callback connected to the EMLSR Manager MainPhySwitch trace source. | |
|  Protected Member Functions inherited from ns3::TestCase | |
| TestCase (std::string name) | |
| Constructor. | |
| void | AddTestCase (TestCase *testCase, Duration duration=Duration::QUICK) | 
| Add an individual child TestCase to this test suite. | |
| TestCase * | GetParent () const | 
| Get the parent of this TestCase. | |
| bool | IsStatusFailure () const | 
| Check if any tests failed. | |
| bool | IsStatusSuccess () const | 
| Check if all tests passed. | |
| void | SetDataDir (std::string directory) | 
| Set the data directory where reference trace files can be found. | |
| void | ReportTestFailure (std::string cond, std::string actual, std::string limit, std::string message, std::string file, int32_t line) | 
| Log the failure of this TestCase. | |
| bool | MustAssertOnFailure () const | 
| Check if this run should assert on failure. | |
| bool | MustContinueOnFailure () const | 
| Check if this run should continue on failure. | |
| std::string | CreateDataDirFilename (std::string filename) | 
| Construct the full path to a file in the data directory. | |
| std::string | CreateTempDirFilename (std::string filename) | 
| Construct the full path to a file in a temporary directory. | |
| Private Member Functions | |
| void | StartTraffic () override | 
| Start the generation of traffic (needs to be overridden) | |
| Private Attributes | |
| std::optional< uint8_t > | m_1stTfLinkId | 
| ID of the link on which the first TF is sent. | |
| bool | m_enableBsrp | 
| whether MU scheduler sends BSRP TFs | |
| bool | m_protectSingleExchange | 
| whether single protection mechanism is used | |
| Time | m_startAccessReq | 
| start time of the first AP MLD access request via MU scheduler | |
| std::size_t | m_txPsdusPos | 
| position in the vector of TX PSDUs of the first ICF | |
| Additional Inherited Members | |
|  Public Types inherited from EmlsrOperationsTestBase | |
| enum | TrafficDirection : uint8_t { DOWNLINK = 0 , UPLINK } | 
| Enumeration for traffic directions.  More... | |
|  Public Types inherited from ns3::TestCase | |
| enum class | Duration { QUICK = 1 , EXTENSIVE = 2 , TAKES_FOREVER = 3 } | 
| How long the test takes to execute.  More... | |
|  Protected Attributes inherited from EmlsrOperationsTestBase | |
| Ptr< ApWifiMac > | m_apMac | 
| AP wifi MAC. | |
| std::array< std::string, 3 > | m_channelsStr | 
| array of strings defining the channels for the MLD links | |
| std::vector< PacketSocketAddress > | m_dlSockets | 
| packet socket address for DL traffic | |
| Time | m_duration {0} | 
| simulation duration | |
| std::vector< uint8_t > | m_establishBaDl {} | 
| the TIDs for which BA needs to be established with the AP as originator | |
| std::vector< uint8_t > | m_establishBaUl {} | 
| the TIDs for which BA needs to be established with the AP as recipient | |
| const std::array< FrequencyRange, 3 > | m_freqRanges | 
| array of frequency ranges for MLD links | |
| uint16_t | m_lastAid {0} | 
| AID of last associated station. | |
| std::set< uint8_t > | m_linksToEnableEmlsrOn | 
| IDs of the links on which EMLSR mode has to be enabled. | |
| uint8_t | m_mainPhyId {0} | 
| ID of the main PHY. | |
| std::size_t | m_nEmlsrStations {1} | 
| number of stations to create that activate EMLSR | |
| std::size_t | m_nNonEmlsrStations {0} | 
| number of stations to create that do not activate EMLSR | |
| std::size_t | m_nPhysPerEmlsrDevice {3} | 
| number of PHYs per EMLSR client | |
| std::vector< Time > | m_paddingDelay | 
| Padding Delay advertised by the non-AP MLD. | |
| bool | m_putAuxPhyToSleep {false} | 
| whether aux PHYs are put to sleep during DL/UL TXOPs | |
| uint64_t | m_rngRun {1} | 
| RNG run value. | |
| uint32_t | m_rngSeed {1} | 
| RNG seed value. | |
| std::vector< Ptr< StaWifiMac > > | m_staMacs | 
| MACs of the non-AP MLDs. | |
| uint16_t | m_startAid {1} | 
| first AID to allocate to stations | |
| int64_t | m_streamNo {5} | 
| RNG stream number. | |
| std::map< std::size_t, std::shared_ptr< EmlsrMainPhySwitchTrace > > | m_traceInfo | 
| EMLSR client ID-indexed map of trace info from last main PHY switch. | |
| std::vector< Time > | m_transitionDelay | 
| Transition Delay advertised by the non-AP MLD. | |
| Time | m_transitionTimeout {MicroSeconds(128)} | 
| Transition Timeout advertised by the AP MLD. | |
| std::vector< FrameInfo > | m_txPsdus | 
| transmitted PSDUs | |
| std::vector< PacketSocketAddress > | m_ulSockets | 
| packet socket address for UL traffic | |
Check UL OFDMA operations with EMLSR clients.
This test considers an AP MLD and an EMLSR client and a non-AP MLD that setup three links with the AP MLD. Once block ack agreements (for TID 0) are established for the UL direction, the AP MLD starts requesting channel access (on all the links) through the Multi-User scheduler. Given that links are idle, AP MLD accesses the channel on all the links and concurrently sends Trigger Frames. When the transmission of the first Trigger Frame is over, a client application on the EMLSR client generates two packets addressed to the AP MLD.
It is checked that:
It is also checked that, when sending BSRP TF is enabled and the single protection mechanism is used, the QoS Null frames sent in response to the BSRP TF acting as ICF have a Duration/ID of zero but the EMLSR client does not consider the TXOP ended when the transmission of the QoS Null frame ends (because in this case the ns3::EhtFrameExchangeManager::EarlyTxopEndDetect attribute is set to false) and therefore correctly receives the Basic Trigger Frame sent after a SIFS.
Definition at line 402 of file wifi-emlsr-basic-exchanges-test.h.
| EmlsrUlOfdmaTest::EmlsrUlOfdmaTest | ( | bool | enableBsrp, | 
| bool | protectSingleExchange ) | 
Constructor.
| enableBsrp | whether MU scheduler sends BSRP TFs | 
| protectSingleExchange | whether single protection mechanism is used | 
Definition at line 2724 of file wifi-emlsr-basic-exchanges-test.cc.
References EmlsrOperationsTestBase::EmlsrOperationsTestBase(), EmlsrOperationsTestBase::m_duration, m_enableBsrp, EmlsrOperationsTestBase::m_establishBaDl, EmlsrOperationsTestBase::m_establishBaUl, EmlsrOperationsTestBase::m_linksToEnableEmlsrOn, EmlsrOperationsTestBase::m_mainPhyId, EmlsrOperationsTestBase::m_nEmlsrStations, EmlsrOperationsTestBase::m_nNonEmlsrStations, m_protectSingleExchange, m_startAccessReq, m_txPsdusPos, and ns3::Seconds().
 Here is the call graph for this function:
 Here is the call graph for this function:| 
 | protected | 
Check that the simulation produced the expected results.
Sending BSRP TF disabled.
The figure assumes that link 0 is used to send the first Trigger Frame after that the AP MLD requests channel access through the Multi-user scheduler. The first Trigger Frame is MU-RTS because EMLSR client needs an ICF; the other Trigger Frames are Basic TFs and do not solicit the EMLSR client. ┌─────┐ ┌─────┐ ┌──────┐ │ MU │ │Basic│ │Multi-│ [link 0] │ RTS │ │ TF │ │STA BA│ ───────────┴─────┴┬───┬┴─────┴┬────────┬─┴──────┴─────────────── │CTS│ │QoS Null│ ├───┤ ├────────┤ │CTS│ │QoS Data│ └───┘ └────────┘
┌─────┐ │Basic│ [link 1] │ TF │ ─────────────┴─────┴┬────┬────────────────────────────────────── │QoS │ │Null│ └────┘
┌─────┐ │Basic│ [link 2] │ TF │ ─────────────┴─────┴┬────┬────────────────────────────────────── │QoS │ │Null│ └────┘
Sending BSRP TF enabled.
The figure assumes that link 0 is used to send the first Trigger Frame after that the AP MLD requests channel access through the Multi-user scheduler. The first Trigger Frames are all BSRP Trigger Frames, but only the first one solicits the EMLSR client, too. ┌─────┐ ┌─────┐ ┌──────┐ │BSRP │ │Basic│ │Multi-│ [link 0] │ TF │ │ TF │ │STA BA│ ───────────┴─────┴┬────────┬┴─────┴┬────────┬─┴──────┴────────── │QoS Null│ │QoS Data│ ├────────┤ └────────┘ │QoS Null│ └────────┘
┌─────┐ │BSRP │ [link 1] │ TF │ ─────────────┴─────┴┬────┬────────────────────────────────────── │QoS │ │Null│ └────┘
┌─────┐ │BSRP │ [link 2] │ TF │ ─────────────┴─────┴┬────┬────────────────────────────────────── │QoS │ │Null│ └────┘
Definition at line 2896 of file wifi-emlsr-basic-exchanges-test.cc.
References ns3::BASIC_TRIGGER, ns3::BSRP_TRIGGER, ns3::CtrlTriggerHeader::GetNUserInfoFields(), ns3::CtrlTriggerHeader::GetType(), ns3::CtrlBAckResponseHeader::IsMultiSta(), m_enableBsrp, EmlsrOperationsTestBase::m_staMacs, EmlsrOperationsTestBase::m_txPsdus, m_txPsdusPos, ns3::MU_RTS_TRIGGER, NS_TEST_ASSERT_MSG_EQ, NS_TEST_ASSERT_MSG_GT, NS_TEST_EXPECT_MSG_EQ, and NS_TEST_EXPECT_MSG_GT.
Referenced by DoRun().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| 
 | overrideprotectedvirtual | 
Implementation to actually run this TestCase.
Subclasses should override this method to conduct their tests.
Implements ns3::TestCase.
Definition at line 2872 of file wifi-emlsr-basic-exchanges-test.cc.
References CheckResults(), ns3::Simulator::Destroy(), EmlsrOperationsTestBase::m_duration, ns3::Simulator::Run(), and ns3::Simulator::Stop().
 Here is the call graph for this function:
 Here is the call graph for this function:| 
 | overrideprotectedvirtual | 
Implementation to do any local setup required for this TestCase.
Subclasses should override this method to perform any costly per-test setup before DoRun is invoked.
Reimplemented from EmlsrOperationsTestBase.
Definition at line 2743 of file wifi-emlsr-basic-exchanges-test.cc.
References ns3::AC_BE, ns3::CreateObjectWithAttributes(), EmlsrOperationsTestBase::DoSetup(), EmlsrOperationsTestBase::m_apMac, m_enableBsrp, m_protectSingleExchange, EmlsrOperationsTestBase::m_transitionDelay, ns3::MicroSeconds(), and ns3::Config::SetDefault().
 Here is the call graph for this function:
 Here is the call graph for this function:| 
 | overrideprivatevirtual | 
Start the generation of traffic (needs to be overridden)
Reimplemented from EmlsrOperationsTestBase.
Definition at line 2883 of file wifi-emlsr-basic-exchanges-test.cc.
References EmlsrOperationsTestBase::m_apMac, m_startAccessReq, ns3::MilliSeconds(), ns3::Simulator::Now(), NS_LOG_INFO, and NS_TEST_ASSERT_MSG_NE.
 Here is the call graph for this function:
 Here is the call graph for this function:| 
 | overrideprotectedvirtual | 
Callback invoked when a FEM passes PSDUs to the PHY.
| mac | the MAC transmitting the PSDUs | 
| phyId | the ID of the PHY transmitting the PSDUs | 
| psduMap | the PSDU map | 
| txVector | the TX vector | 
| txPowerW | the tx power in Watts | 
Reimplemented from EmlsrOperationsTestBase.
Definition at line 2765 of file wifi-emlsr-basic-exchanges-test.cc.
References ns3::WifiPhy::CalculateTxDuration(), EmlsrOperationsTestBase::GetApplication(), ns3::CtrlBAckResponseHeader::IsMultiSta(), m_1stTfLinkId, m_enableBsrp, m_protectSingleExchange, EmlsrOperationsTestBase::m_staMacs, m_startAccessReq, EmlsrOperationsTestBase::m_txPsdus, m_txPsdusPos, ns3::MAX_PROPAGATION_DELAY, ns3::MicroSeconds(), ns3::Simulator::Now(), ns3::Time::NS, NS_LOG_INFO, NS_TEST_EXPECT_MSG_EQ, ns3::Simulator::Schedule(), ns3::StaticCast(), ns3::Simulator::Stop(), EmlsrOperationsTestBase::Transmit(), EmlsrOperationsTestBase::UPLINK, ns3::WIFI_MAC_CTL_BACKRESP, ns3::WIFI_MAC_CTL_TRIGGER, and ns3::WIFI_MAC_QOSDATA_NULL.
 Here is the call graph for this function:
 Here is the call graph for this function:| 
 | private | 
ID of the link on which the first TF is sent.
Definition at line 434 of file wifi-emlsr-basic-exchanges-test.h.
Referenced by Transmit().
| 
 | private | 
whether MU scheduler sends BSRP TFs
Definition at line 430 of file wifi-emlsr-basic-exchanges-test.h.
Referenced by EmlsrUlOfdmaTest(), CheckResults(), DoSetup(), and Transmit().
| 
 | private | 
whether single protection mechanism is used
Definition at line 431 of file wifi-emlsr-basic-exchanges-test.h.
Referenced by EmlsrUlOfdmaTest(), DoSetup(), and Transmit().
| 
 | private | 
start time of the first AP MLD access request via MU scheduler
Definition at line 433 of file wifi-emlsr-basic-exchanges-test.h.
Referenced by EmlsrUlOfdmaTest(), StartTraffic(), and Transmit().
| 
 | private | 
position in the vector of TX PSDUs of the first ICF
Definition at line 432 of file wifi-emlsr-basic-exchanges-test.h.
Referenced by EmlsrUlOfdmaTest(), CheckResults(), and Transmit().