The Wifi MAC high model for a non-AP STA in a BSS. More...
#include "sta-wifi-mac.h"
Classes | |
struct | ApInfo |
Struct to hold information regarding observed AP through active/passive scanning. More... | |
struct | StaLinkEntity |
Structure holding information specific to a single link. More... | |
Public Types | |
using | MgtFrameType = std::variant< MgtBeaconHeader, MgtProbeResponseHeader, MgtAssocResponseHeader > |
type of the management frames used to get info about APs More... | |
![]() | |
typedef Callback< void, Ptr< const Packet >, Mac48Address, Mac48Address > | ForwardUpCallback |
This type defines the callback of a higher layer that a WifiMac(-derived) object invokes to pass a packet up the stack. More... | |
using | OriginatorAgreementOptConstRef = std::optional< std::reference_wrapper< const OriginatorBlockAckAgreement > > |
optional const reference to OriginatorBlockAckAgreement More... | |
using | RecipientAgreementOptConstRef = std::optional< std::reference_wrapper< const RecipientBlockAckAgreement > > |
optional const reference to RecipientBlockAckAgreement More... | |
Public Member Functions | |
StaWifiMac () | |
~StaWifiMac () override | |
int64_t | AssignStreams (int64_t stream) |
Assign a fixed random variable stream number to the random variables used by this model. More... | |
bool | CanForwardPacketsTo (Mac48Address to) const override |
Return true if packets can be forwarded to the given destination, false otherwise. More... | |
void | Enqueue (Ptr< Packet > packet, Mac48Address to) override |
uint16_t | GetAssociationId () const |
Return the association ID. More... | |
std::set< uint8_t > | GetSetupLinkIds () const |
Get the IDs of the setup links (if any). More... | |
bool | IsAssociated () const |
Return whether we are associated with an AP. More... | |
void | NotifyChannelSwitching (uint8_t linkId) override |
Notify that channel on the given link has been switched. More... | |
void | ScanningTimeout (const std::optional< ApInfo > &bestAp) |
This method is called after wait beacon timeout or wait probe request timeout has occurred. More... | |
void | SendProbeRequest () |
Forward a probe request packet to the DCF. More... | |
void | SetAssocManager (Ptr< WifiAssocManager > assocManager) |
Set the Association Manager. More... | |
void | SetWifiPhys (const std::vector< Ptr< WifiPhy >> &phys) override |
![]() | |
WifiMac () | |
WifiMac (const WifiMac &)=delete | |
~WifiMac () override | |
virtual void | ConfigureStandard (WifiStandard standard) |
virtual void | Enqueue (Ptr< Packet > packet, Mac48Address to, Mac48Address from) |
Mac48Address | GetAddress () const |
OriginatorAgreementOptConstRef | GetBaAgreementEstablishedAsOriginator (Mac48Address recipient, uint8_t tid) const |
RecipientAgreementOptConstRef | GetBaAgreementEstablishedAsRecipient (Mac48Address originator, uint8_t tid) const |
BlockAckReqType | GetBarTypeAsOriginator (const Mac48Address &recipient, uint8_t tid) const |
BlockAckReqType | GetBarTypeAsRecipient (Mac48Address originator, uint8_t tid) const |
BlockAckType | GetBaTypeAsOriginator (const Mac48Address &recipient, uint8_t tid) const |
BlockAckType | GetBaTypeAsRecipient (Mac48Address originator, uint8_t tid) const |
Mac48Address | GetBssid (uint8_t linkId) const |
Ptr< ChannelAccessManager > | GetChannelAccessManager (uint8_t linkId=SINGLE_LINK_OP_ID) const |
Get the Channel Access Manager associated with the given link. More... | |
Ptr< WifiNetDevice > | GetDevice () const |
Return the device this PHY is associated with. More... | |
bool | GetDsssSupported (uint8_t linkId) const |
Return whether the device supports DSSS on the given link. More... | |
EhtCapabilities | GetEhtCapabilities (uint8_t linkId) const |
Return the EHT capabilities of the device for the given link. More... | |
Ptr< EhtConfiguration > | GetEhtConfiguration () const |
bool | GetEhtSupported () const |
Return whether the device supports EHT. More... | |
bool | GetEhtSupported (const Mac48Address &address) const |
bool | GetErpSupported (uint8_t linkId) const |
Return whether the device supports ERP on the given link. More... | |
ExtendedCapabilities | GetExtendedCapabilities () const |
Return the extended capabilities of the device. More... | |
Ptr< FrameExchangeManager > | GetFrameExchangeManager (uint8_t linkId=SINGLE_LINK_OP_ID) const |
Get the Frame Exchange Manager associated with the given link. More... | |
HeCapabilities | GetHeCapabilities (uint8_t linkId) const |
Return the HE capabilities of the device for the given link. More... | |
Ptr< HeConfiguration > | GetHeConfiguration () const |
bool | GetHeSupported () const |
Return whether the device supports HE. More... | |
bool | GetHeSupported (const Mac48Address &address) const |
HtCapabilities | GetHtCapabilities (uint8_t linkId) const |
Return the HT capabilities of the device for the given link. More... | |
Ptr< HtConfiguration > | GetHtConfiguration () const |
bool | GetHtSupported () const |
Return whether the device supports HT. More... | |
bool | GetHtSupported (const Mac48Address &address) const |
virtual std::optional< uint8_t > | GetLinkIdByAddress (const Mac48Address &address) const |
Get the ID of the link having the given MAC address, if any. More... | |
Mac48Address | GetLocalAddress (const Mac48Address &remoteAddr) const |
Get the local MAC address used to communicate with a remote STA. More... | |
Ptr< WifiMacQueueScheduler > | GetMacQueueScheduler () const |
Get the wifi MAC queue scheduler. More... | |
uint32_t | GetMaxAmpduSize (AcIndex ac) const |
Return the maximum A-MPDU size of the given Access Category. More... | |
uint16_t | GetMaxAmsduSize (AcIndex ac) const |
Return the maximum A-MSDU size of the given Access Category. More... | |
std::optional< Mac48Address > | GetMldAddress (const Mac48Address &remoteAddr) const |
uint8_t | GetNLinks () const |
Get the number of links (can be greater than 1 for 11be devices only). More... | |
bool | GetQosSupported () const |
Return whether the device supports QoS. More... | |
Ptr< QosTxop > | GetQosTxop (AcIndex ac) const |
Accessor for a specified EDCA object. More... | |
Ptr< QosTxop > | GetQosTxop (uint8_t tid) const |
Accessor for a specified EDCA object. More... | |
Ssid | GetSsid () const |
Ptr< Txop > | GetTxop () const |
Accessor for the Txop object. More... | |
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, or a null pointer, otherwise. More... | |
TypeOfStation | GetTypeOfStation () const |
Return the type of station. More... | |
VhtCapabilities | GetVhtCapabilities (uint8_t linkId) const |
Return the VHT capabilities of the device for the given link. More... | |
Ptr< VhtConfiguration > | GetVhtConfiguration () const |
bool | GetVhtSupported (const Mac48Address &address) const |
bool | GetVhtSupported (uint8_t linkId) const |
Return whether the device supports VHT on the given link. More... | |
Ptr< WifiPhy > | GetWifiPhy (uint8_t linkId=SINGLE_LINK_OP_ID) const |
Ptr< WifiRemoteStationManager > | GetWifiRemoteStationManager (uint8_t linkId=0) const |
void | NotifyPromiscRx (Ptr< const Packet > packet) |
void | NotifyRx (Ptr< const Packet > packet) |
void | NotifyRxDrop (Ptr< const Packet > packet) |
void | NotifyTx (Ptr< const Packet > packet) |
void | NotifyTxDrop (Ptr< const Packet > packet) |
WifiMac & | operator= (const WifiMac &)=delete |
void | ResetWifiPhys () |
Remove currently attached WifiPhy objects from this MAC. More... | |
virtual void | SetAddress (Mac48Address address) |
void | SetBssid (Mac48Address bssid, uint8_t linkId) |
void | SetCtsToSelfSupported (bool enable) |
Enable or disable CTS-to-self feature. More... | |
void | SetDevice (const Ptr< WifiNetDevice > device) |
Sets the device this PHY is associated with. More... | |
void | SetForwardUpCallback (ForwardUpCallback upCallback) |
void | SetLinkDownCallback (Callback< void > linkDown) |
virtual void | SetLinkUpCallback (Callback< void > linkUp) |
virtual void | SetMacQueueScheduler (Ptr< WifiMacQueueScheduler > scheduler) |
Set the wifi MAC queue scheduler. More... | |
void | SetPromisc () |
Sets the interface in promiscuous mode. More... | |
void | SetSsid (Ssid ssid) |
void | SetTypeOfStation (TypeOfStation type) |
This method is invoked by a subclass to specify what type of station it is implementing. More... | |
void | SetWifiRemoteStationManager (Ptr< WifiRemoteStationManager > stationManager) |
void | SetWifiRemoteStationManagers (const std::vector< Ptr< WifiRemoteStationManager >> &stationManagers) |
virtual bool | SupportsSendFrom () const |
![]() | |
Object () | |
Constructor. More... | |
~Object () override | |
Destructor. More... | |
void | AggregateObject (Ptr< Object > other) |
Aggregate two Objects together. More... | |
void | Dispose () |
Dispose of this Object. More... | |
AggregateIterator | GetAggregateIterator () const |
Get an iterator to the Objects aggregated to this one. More... | |
TypeId | GetInstanceTypeId () const override |
Get the most derived TypeId for this Object. More... | |
template<typename T > | |
Ptr< T > | GetObject () const |
Get a pointer to the requested aggregated Object. More... | |
template<> | |
Ptr< Object > | GetObject () const |
Specialization of () for objects of type ns3::Object. More... | |
template<typename T > | |
Ptr< T > | GetObject (TypeId tid) const |
Get a pointer to the requested aggregated Object by TypeId. More... | |
template<> | |
Ptr< Object > | GetObject (TypeId tid) const |
Specialization of (TypeId tid) for objects of type ns3::Object. More... | |
void | Initialize () |
Invoke DoInitialize on all Objects aggregated to this one. More... | |
bool | IsInitialized () const |
Check if the object has been initialized. More... | |
![]() | |
SimpleRefCount () | |
Default constructor. More... | |
SimpleRefCount (const SimpleRefCount &o[[maybe_unused]]) | |
Copy constructor. More... | |
uint32_t | GetReferenceCount () const |
Get the reference count of the object. More... | |
SimpleRefCount & | operator= (const SimpleRefCount &o[[maybe_unused]]) |
Assignment operator. More... | |
void | Ref () const |
Increment the reference count. More... | |
void | Unref () const |
Decrement the reference count. More... | |
![]() | |
virtual | ~ObjectBase () |
Virtual destructor. More... | |
void | GetAttribute (std::string name, AttributeValue &value) const |
Get the value of an attribute, raising fatal errors if unsuccessful. More... | |
bool | GetAttributeFailSafe (std::string name, AttributeValue &value) const |
Get the value of an attribute without raising errors. More... | |
void | SetAttribute (std::string name, const AttributeValue &value) |
Set a single attribute, raising fatal errors if unsuccessful. More... | |
bool | SetAttributeFailSafe (std::string name, const AttributeValue &value) |
Set a single attribute without raising errors. More... | |
bool | TraceConnect (std::string name, std::string context, const CallbackBase &cb) |
Connect a TraceSource to a Callback with a context. More... | |
bool | TraceConnectWithoutContext (std::string name, const CallbackBase &cb) |
Connect a TraceSource to a Callback without a context. More... | |
bool | TraceDisconnect (std::string name, std::string context, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected with a context. More... | |
bool | TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected without a context. More... | |
Static Public Member Functions | |
static TypeId | GetTypeId () |
Get the type ID. More... | |
![]() | |
static TypeId | GetTypeId () |
Get the type ID. More... | |
![]() | |
static TypeId | GetTypeId () |
Register this type. More... | |
![]() | |
static TypeId | GetTypeId () |
Get the type ID. More... | |
Protected Member Functions | |
StaLinkEntity & | GetLink (uint8_t linkId) const |
Get a reference to the link associated with the given ID. More... | |
![]() | |
virtual void | ConfigureContentionWindow (uint32_t cwMin, uint32_t cwMax) |
virtual void | DeaggregateAmsduAndForward (Ptr< const WifiMpdu > mpdu) |
This method can be called to de-aggregate an A-MSDU and forward the constituent packets up the stack. More... | |
void | DoDispose () override |
Destructor implementation. More... | |
void | DoInitialize () override |
Initialize() implementation. More... | |
void | ForwardUp (Ptr< const Packet > packet, Mac48Address from, Mac48Address to) |
Forward the packet up to the device. More... | |
Ptr< QosTxop > | GetBEQueue () const |
Accessor for the AC_BE channel access function. More... | |
Ptr< QosTxop > | GetBKQueue () const |
Accessor for the AC_BK channel access function. More... | |
LinkEntity & | GetLink (uint8_t linkId) const |
Get a reference to the link associated with the given ID. More... | |
bool | GetShortSlotTimeSupported () const |
Ptr< QosTxop > | GetVIQueue () const |
Accessor for the AC_VI channel access function. More... | |
Ptr< QosTxop > | GetVOQueue () const |
Accessor for the AC_VO channel access function. More... | |
void | SetQosSupported (bool enable) |
Enable or disable QoS support for the device. More... | |
void | SetShortSlotTimeSupported (bool enable) |
Enable or disable short slot time feature. More... | |
![]() | |
Object (const Object &o) | |
Copy an Object. More... | |
virtual void | NotifyNewAggregate () |
Notify all Objects aggregated to this one of a new Object being aggregated. More... | |
![]() | |
void | ConstructSelf (const AttributeConstructionList &attributes) |
Complete construction of ObjectBase; invoked by derived classes. More... | |
virtual void | NotifyConstructionCompleted () |
Notifier called once the ObjectBase is fully constructed. More... | |
Private Types | |
using | LinkSetupCallback = void(*)(uint8_t, Mac48Address) |
TracedCallback signature for link setup completed/canceled events. More... | |
enum | MacState { ASSOCIATED , SCANNING , WAIT_ASSOC_RESP , UNASSOCIATED , REFUSED } |
The current MAC state of the STA. More... | |
Private Member Functions | |
void | AssocRequestTimeout () |
This method is called after the association timeout occurred. More... | |
bool | CheckSupportedRates (std::variant< MgtBeaconHeader, MgtProbeResponseHeader > frame, uint8_t linkId) |
Determine whether the supported rates indicated in a given Beacon frame or Probe Response frame fit with the configured membership selector. More... | |
std::unique_ptr< LinkEntity > | CreateLinkEntity () const override |
Create a LinkEntity object. More... | |
void | Disassociated (uint8_t linkId) |
Check if any enabled link remains after the given link is disabled (because, e.g., the maximum number of beacons is missed or the channel is switched). More... | |
void | DoDispose () override |
Destructor implementation. More... | |
Mac48Address | DoGetLocalAddress (const Mac48Address &remoteAddr) const override |
This method is called if this device is an MLD to determine the MAC address of the affiliated STA used to communicate with the single link device having the given MAC address. More... | |
void | DoInitialize () override |
Initialize() implementation. More... | |
bool | GetActiveProbing () const |
Return whether active probing is enabled. More... | |
std::variant< MgtAssocRequestHeader, MgtReassocRequestHeader > | GetAssociationRequest (bool isReassoc, uint8_t linkId) const |
Get the (Re)Association Request frame to send on a given link. More... | |
CapabilityInformation | GetCapabilities (uint8_t linkId) const |
Return the Capability information for the given link. More... | |
WifiScanParams::Channel | GetCurrentChannel (uint8_t linkId) const |
Get the current primary20 channel used on the given link as a (channel number, PHY band) pair. More... | |
MultiLinkElement | GetMultiLinkElement (bool isReassoc, uint8_t linkId) const |
Return the Multi-Link Element to include in the management frames transmitted on the given link. More... | |
SupportedRates | GetSupportedRates (uint8_t linkId) const |
Return an instance of SupportedRates that contains all rates that we support including HT rates. More... | |
bool | IsWaitAssocResp () const |
Return whether we are waiting for an association response from an AP. More... | |
void | MissedBeacons (uint8_t linkId) |
This method is called after we have not received a beacon from the AP on the given link. More... | |
void | PhyCapabilitiesChanged () |
Indicate that PHY capabilities have changed. More... | |
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 been received on the given link. More... | |
void | ReceiveAssocResp (Ptr< const WifiMpdu > mpdu, uint8_t linkId) |
Process the (Re)Association Response frame received on the given link. More... | |
void | ReceiveBeacon (Ptr< const WifiMpdu > mpdu, uint8_t linkId) |
Process the Beacon frame received on the given link. More... | |
void | ReceiveProbeResp (Ptr< const WifiMpdu > mpdu, uint8_t linkId) |
Process the Probe Response frame received on the given link. More... | |
void | RestartBeaconWatchdog (Time delay, uint8_t linkId) |
Restarts the beacon timer for the given link. More... | |
void | SendAssociationRequest (bool isReassoc) |
Forward an association or reassociation request packet to the DCF. More... | |
void | SetActiveProbing (bool enable) |
Enable or disable active probing. More... | |
void | SetEdcaParameters (AcIndex ac, uint32_t cwMin, uint32_t cwMax, uint8_t aifsn, Time txopLimit) |
Set the EDCA parameters. More... | |
void | SetMuEdcaParameters (AcIndex ac, uint16_t cwMin, uint16_t cwMax, uint8_t aifsn, Time muEdcaTimer) |
Set the MU EDCA parameters. More... | |
void | SetState (MacState value) |
Set the current MAC state. More... | |
void | StartScanning () |
Start the scanning process which trigger active or passive scanning based on the active probing flag. More... | |
void | TryToEnsureAssociated () |
Try to ensure that we are associated with an AP by taking an appropriate action depending on the current association status. More... | |
void | UpdateApInfo (const MgtFrameType &frame, const Mac48Address &apAddr, const Mac48Address &bssid, uint8_t linkId) |
Update associated AP's information from the given management frame (Beacon, Probe Response or Association Response). More... | |
Friends | |
class | ::AmpduAggregationTest |
Allow test cases to access private members. More... | |
class | ::HeAggregationTest |
Allow test cases to access private members. More... | |
class | ::MultiLinkOperationsTestBase |
Allow test cases to access private members. More... | |
class | ::TwoLevelAggregationTest |
Allow test cases to access private members. More... | |
Additional Inherited Members | |
![]() | |
Callback< void > | m_linkDown |
Callback when a link is down. More... | |
Callback< void > | m_linkUp |
Callback when a link is up. More... | |
Ptr< MacRxMiddle > | m_rxMiddle |
RX middle (defragmentation etc.) More... | |
Ptr< WifiMacQueueScheduler > | m_scheduler |
wifi MAC queue scheduler More... | |
Ptr< MacTxMiddle > | m_txMiddle |
TX middle (aggregation etc.) More... | |
Ptr< Txop > | m_txop |
TXOP used for transmission of frames to non-QoS peers. More... | |
![]() | |
static TypeId | GetObjectIid () |
Ensure the TypeId for ObjectBase gets fully configured to anchor the inheritance tree properly. More... | |
The Wifi MAC high model for a non-AP STA in a BSS.
The state machine is as follows:
┌───────────┐ ┌────────────────┐ ┌─────────────┐ │ Start │ ┌─────┤ Associated ◄───────────────────┐ ┌──► Refused │ └─┬─────────┘ │ └────────────────┘ │ │ └─────────────┘ │ │ │ │ │ │ ┌─────────────────────────────────────┐ │ │ │ │ │ │ │ │ │ ┌─────────────▼─▼──┐ ┌──────────────┐ ┌───┴──▼────┴───────────────────┐ └──► Unassociated ├───────► Scanning ├───────► Wait AssociationiResponse │ └──────────────────┘ └──────┬──▲────┘ └───────────────┬──▲────────────┘ │ │ │ │ │ │ │ │ └──┘ └──┘
Notes:
ns3::StaWifiMac is accessible through the following paths with Config::Set and Config::Connect:
Time
+9.22337e+18ns:+9.22337e+18ns Time
+9.22337e+18ns:+9.22337e+18ns Time
+9.22337e+18ns:+9.22337e+18ns Ssid
Size of this type is 792 bytes (on a 64-bit architecture).
Definition at line 123 of file sta-wifi-mac.h.
|
private |
TracedCallback signature for link setup completed/canceled events.
Definition at line 505 of file sta-wifi-mac.h.
using ns3::StaWifiMac::MgtFrameType = std::variant<MgtBeaconHeader, MgtProbeResponseHeader, MgtAssocResponseHeader> |
type of the management frames used to get info about APs
Definition at line 136 of file sta-wifi-mac.h.
|
private |
The current MAC state of the STA.
Enumerator | |
---|---|
ASSOCIATED | |
SCANNING | |
WAIT_ASSOC_RESP | |
UNASSOCIATED | |
REFUSED |
Definition at line 268 of file sta-wifi-mac.h.
ns3::StaWifiMac::StaWifiMac | ( | ) |
Definition at line 128 of file sta-wifi-mac.cc.
References NS_LOG_FUNCTION, ns3::WifiMac::SetTypeOfStation(), and ns3::STA.
|
override |
Definition at line 159 of file sta-wifi-mac.cc.
References NS_LOG_FUNCTION.
int64_t ns3::StaWifiMac::AssignStreams | ( | int64_t | stream | ) |
Assign a fixed random variable stream number to the random variables used by this model.
Return the number of streams (possibly zero) that have been assigned.
stream | first stream index to use |
Definition at line 182 of file sta-wifi-mac.cc.
References m_probeDelay, NS_LOG_FUNCTION, and ns3::RandomVariableStream::SetStream().
|
private |
This method is called after the association timeout occurred.
We switch the state to WAIT_ASSOC_RESP and re-send an association request.
Definition at line 609 of file sta-wifi-mac.cc.
References NS_LOG_FUNCTION, SendAssociationRequest(), SetState(), and WAIT_ASSOC_RESP.
Referenced by SendAssociationRequest().
|
overridevirtual |
Return true if packets can be forwarded to the given destination, false otherwise.
to | the address to which the packet should be sent |
Implements ns3::WifiMac.
Definition at line 746 of file sta-wifi-mac.cc.
References IsAssociated().
Referenced by Enqueue().
|
private |
Determine whether the supported rates indicated in a given Beacon frame or Probe Response frame fit with the configured membership selector.
frame | the given Beacon or Probe Response frame |
linkId | ID of the link the mgt frame was received over |
Definition at line 1164 of file sta-wifi-mac.cc.
References ns3::WifiPhy::GetBssMembershipSelectorList(), ns3::WifiMac::GetWifiPhy(), ns3::SupportedRates::IsBssMembershipSelectorRate(), NS_LOG_DEBUG, and NS_LOG_FUNCTION.
Referenced by ReceiveBeacon(), and ReceiveProbeResp().
|
overrideprivatevirtual |
Create a LinkEntity object.
Reimplemented from ns3::WifiMac.
Definition at line 170 of file sta-wifi-mac.cc.
|
private |
Check if any enabled link remains after the given link is disabled (because, e.g., the maximum number of beacons is missed or the channel is switched).
If no enabled link remains, proceed with disassociation.
linkId | the ID of the given link |
Definition at line 646 of file sta-wifi-mac.cc.
References ns3::StaWifiMac::StaLinkEntity::apLinkId, ns3::WifiMac::GetBssid(), GetLink(), ns3::WifiRemoteStationManager::GetMldAddress(), ns3::WifiMac::GetNLinks(), ns3::WifiMac::GetWifiRemoteStationManager(), m_aid, m_deAssocLogger, m_setupCanceled, NS_LOG_DEBUG, NS_LOG_FUNCTION, ns3::WifiMac::LinkEntity::phy, ns3::WifiPhy::ResumeFromOff(), SetState(), TryToEnsureAssociated(), and UNASSOCIATED.
Referenced by MissedBeacons(), and NotifyChannelSwitching().
|
overrideprivatevirtual |
Destructor implementation.
This method is called by Dispose() or by the Object's destructor, whichever comes first.
Subclasses are expected to implement their real destruction code in an overridden version of this method and chain up to their parent's implementation once they are done. i.e, for simplicity, the destructor of every subclass should be empty and its content should be moved to the associated DoDispose() method.
It is safe to call GetObject() from within this method.
Reimplemented from ns3::Object.
Definition at line 148 of file sta-wifi-mac.cc.
References ns3::WifiMac::DoDispose(), m_assocManager, and NS_LOG_FUNCTION.
|
overrideprivatevirtual |
This method is called if this device is an MLD to determine the MAC address of the affiliated STA used to communicate with the single link device having the given MAC address.
This method is overridden because its implementation depends on the type of station.
remoteAddr | the MAC address of the remote single link device |
Reimplemented from ns3::WifiMac.
Definition at line 737 of file sta-wifi-mac.cc.
References ns3::WifiMac::GetFrameExchangeManager(), GetSetupLinkIds(), and NS_ASSERT_MSG.
|
overrideprivatevirtual |
Initialize() implementation.
This method is called only once by Initialize(). If the user calls Initialize() multiple times, DoInitialize() is called only the first time.
Subclasses are expected to override this method and chain up to their parent's implementation once they are done. It is safe to call GetObject() and AggregateObject() from within this method.
Reimplemented from ns3::Object.
Definition at line 141 of file sta-wifi-mac.cc.
References NS_LOG_FUNCTION, and StartScanning().
|
overridevirtual |
packet | the packet to send. |
to | the address to which the packet should be sent. |
The packet should be enqueued in a TX queue, and should be dequeued as soon as the channel access function determines that access is granted to this MAC.
Implements ns3::WifiMac.
Definition at line 752 of file sta-wifi-mac.cc.
References CanForwardPacketsTo(), ns3::WifiMac::GetAddress(), ns3::WifiMac::GetBssid(), ns3::WifiMac::GetFrameExchangeManager(), ns3::WifiMac::GetMldAddress(), ns3::WifiMac::GetQosSupported(), ns3::WifiMac::GetQosTxop(), GetSetupLinkIds(), ns3::WifiMac::GetTxop(), ns3::WifiMac::GetWifiRemoteStationManager(), ns3::WifiMacHeader::NORMAL_ACK, ns3::WifiMac::NotifyTxDrop(), NS_ASSERT, NS_LOG_FUNCTION, ns3::QosUtilsGetTidForPacket(), ns3::Txop::Queue(), ns3::WifiMacHeader::SetAddr1(), ns3::WifiMacHeader::SetAddr2(), ns3::WifiMacHeader::SetAddr3(), ns3::WifiMacHeader::SetDsNotFrom(), ns3::WifiMacHeader::SetDsTo(), ns3::WifiMacHeader::SetNoOrder(), ns3::WifiMacHeader::SetQosAckPolicy(), ns3::WifiMacHeader::SetQosNoAmsdu(), ns3::WifiMacHeader::SetQosNoEosp(), ns3::WifiMacHeader::SetQosTid(), ns3::WifiMacHeader::SetQosTxopLimit(), ns3::WifiMacHeader::SetType(), TryToEnsureAssociated(), ns3::WIFI_MAC_DATA, and ns3::WIFI_MAC_QOSDATA.
|
private |
Return whether active probing is enabled.
Definition at line 217 of file sta-wifi-mac.cc.
References m_activeProbing.
Referenced by GetTypeId().
uint16_t ns3::StaWifiMac::GetAssociationId | ( | ) | const |
Return the association ID.
Definition at line 198 of file sta-wifi-mac.cc.
References IsAssociated(), m_aid, and NS_ASSERT_MSG.
Referenced by ns3::WifiRemoteStationManager::GetStaId().
|
private |
Get the (Re)Association Request frame to send on a given link.
The returned frame never includes a Multi-Link Element.
isReassoc | whether a Reassociation Request has to be returned |
linkId | the ID of the given link |
Definition at line 295 of file sta-wifi-mac.cc.
References ns3::WifiMac::GetBssid(), GetCapabilities(), ns3::WifiMac::GetEhtCapabilities(), ns3::WifiMac::GetEhtSupported(), ns3::WifiMac::GetExtendedCapabilities(), ns3::WifiMac::GetHeCapabilities(), ns3::WifiMac::GetHeSupported(), ns3::WifiMac::GetHtCapabilities(), ns3::WifiMac::GetHtSupported(), ns3::WifiMac::GetSsid(), GetSupportedRates(), ns3::WifiMac::GetVhtCapabilities(), ns3::WifiMac::GetVhtSupported(), NS_LOG_FUNCTION, and ns3::MgtReassocRequestHeader::SetCurrentApAddress().
Referenced by GetMultiLinkElement(), and SendAssociationRequest().
|
private |
Return the Capability information for the given link.
linkId | the ID of the given link |
Definition at line 1402 of file sta-wifi-mac.cc.
References ns3::WifiMac::GetErpSupported(), ns3::WifiMac::GetShortSlotTimeSupported(), ns3::WifiMac::GetWifiPhy(), ns3::CapabilityInformation::SetShortPreamble(), and ns3::CapabilityInformation::SetShortSlotTime().
Referenced by GetAssociationRequest().
|
private |
Get the current primary20 channel used on the given link as a (channel number, PHY band) pair.
linkId | the ID of the given link |
Definition at line 235 of file sta-wifi-mac.cc.
References ns3::WifiMac::GetWifiPhy(), and third::phy.
Referenced by ReceiveBeacon().
|
protected |
Get a reference to the link associated with the given ID.
linkId | the given link ID |
Definition at line 176 of file sta-wifi-mac.cc.
References ns3::WifiMac::GetLink().
Referenced by Disassociated(), GetMultiLinkElement(), GetSetupLinkIds(), MissedBeacons(), ReceiveAssocResp(), ReceiveBeacon(), RestartBeaconWatchdog(), ScanningTimeout(), and SendAssociationRequest().
|
private |
Return the Multi-Link Element to include in the management frames transmitted on the given link.
isReassoc | whether the Multi-Link Element is included in a Reassociation Request |
linkId | the ID of the given link |
Definition at line 342 of file sta-wifi-mac.cc.
References ns3::MultiLinkElement::AddPerStaProfileSubelement(), ns3::MultiLinkElement::BASIC_VARIANT, ns3::WifiMac::GetAddress(), GetAssociationRequest(), GetLink(), ns3::WifiMac::GetNLinks(), ns3::MultiLinkElement::GetNPerStaProfileSubelements(), ns3::MultiLinkElement::GetPerStaProfile(), NS_LOG_FUNCTION, ns3::MultiLinkElement::PerStaProfileSubelement::SetLinkId(), ns3::MultiLinkElement::SetMldMacAddress(), ns3::WIFI_MAC_MGT_ASSOCIATION_REQUEST, and ns3::WIFI_MAC_MGT_REASSOCIATION_REQUEST.
Referenced by SendAssociationRequest().
std::set< uint8_t > ns3::StaWifiMac::GetSetupLinkIds | ( | ) | const |
Get the IDs of the setup links (if any).
Definition at line 718 of file sta-wifi-mac.cc.
References ns3::StaWifiMac::StaLinkEntity::bssid, GetLink(), ns3::WifiMac::GetNLinks(), and IsAssociated().
Referenced by DoGetLocalAddress(), Enqueue(), ns3::WifiNetDevice::GetAddress(), and Receive().
|
private |
Return an instance of SupportedRates that contains all rates that we support including HT rates.
linkId | the ID of the link for which the request is made |
Definition at line 1382 of file sta-wifi-mac.cc.
References ns3::SupportedRates::AddBssMembershipSelectorRate(), ns3::SupportedRates::AddSupportedRate(), ns3::WifiMac::GetHtSupported(), ns3::WifiMac::GetWifiPhy(), and NS_LOG_DEBUG.
Referenced by GetAssociationRequest(), and SendProbeRequest().
|
static |
Get the type ID.
Definition at line 52 of file sta-wifi-mac.cc.
References GetActiveProbing(), m_assocLogger, m_assocRequestTimeout, m_beaconArrival, m_beaconInfo, m_deAssocLogger, m_maxMissedBeacons, m_probeDelay, m_probeRequestTimeout, m_setupCanceled, m_setupCompleted, m_waitBeaconTimeout, ns3::MakeBooleanAccessor(), ns3::MakeBooleanChecker(), ns3::MakePointerAccessor(), ns3::MakeTimeAccessor(), ns3::MakeTimeChecker(), ns3::MakeTraceSourceAccessor(), ns3::MakeUintegerAccessor(), ns3::MilliSeconds(), ns3::Seconds(), SetActiveProbing(), and ns3::TypeId::SetParent().
bool ns3::StaWifiMac::IsAssociated | ( | ) | const |
Return whether we are associated with an AP.
Definition at line 706 of file sta-wifi-mac.cc.
References ASSOCIATED, and m_state.
Referenced by CanForwardPacketsTo(), GetAssociationId(), GetSetupLinkIds(), ns3::WifiRemoteStationManager::GetStaId(), NotifyChannelSwitching(), PhyCapabilitiesChanged(), Receive(), and ReceiveBeacon().
|
private |
Return whether we are waiting for an association response from an AP.
Definition at line 712 of file sta-wifi-mac.cc.
References m_state, and WAIT_ASSOC_RESP.
Referenced by ReceiveBeacon().
|
private |
This method is called after we have not received a beacon from the AP on the given link.
linkId | the ID of the given link |
Definition at line 617 of file sta-wifi-mac.cc.
References Disassociated(), ns3::WifiPhy::GetDelayUntilIdle(), GetLink(), ns3::WifiMac::GetWifiPhy(), ns3::Simulator::Now(), NS_LOG_DEBUG, NS_LOG_FUNCTION, ns3::Simulator::Schedule(), and ns3::Seconds().
Referenced by RestartBeaconWatchdog().
|
overridevirtual |
Notify that channel on the given link has been switched.
linkId | the ID of the given link |
Reimplemented from ns3::WifiMac.
Definition at line 1458 of file sta-wifi-mac.cc.
References Disassociated(), IsAssociated(), ns3::Object::IsInitialized(), m_assocManager, ns3::WifiMac::NotifyChannelSwitching(), and NS_LOG_FUNCTION.
|
private |
Indicate that PHY capabilities have changed.
Definition at line 1446 of file sta-wifi-mac.cc.
References IsAssociated(), NS_LOG_DEBUG, NS_LOG_FUNCTION, SendAssociationRequest(), SetState(), and WAIT_ASSOC_RESP.
Referenced by SetWifiPhys().
This method acts as the MacRxMiddle receive callback and is invoked to notify us that a frame has been received on the given link.
The implementation is intended to capture logic that is going to be common to all (or most) derived classes. Specifically, handling of Block Ack management frames is dealt with here.
This method will need, however, to be overridden by derived classes so that they can perform their data handling before invoking the base version.
The given link may be undefined in some cases (e.g., in case of QoS Data frames received in the context of a Block Ack agreement – because the BlockAckManager does not have to record the link each buffered MPDU has been received on); in such a cases, the value of linkId should be WIFI_LINKID_UNDEFINED.
mpdu | the MPDU that has been received. |
linkId | the ID of the given link |
Reimplemented from ns3::WifiMac.
Definition at line 837 of file sta-wifi-mac.cc.
References ns3::Mac48Address::ConvertFrom(), ns3::WifiMac::DeaggregateAmsduAndForward(), ns3::WifiMac::ForwardUp(), ns3::WifiMacHeader::GetAddr1(), ns3::WifiMacHeader::GetAddr3(), ns3::WifiMac::GetAddress(), ns3::WifiMac::GetBssid(), ns3::WifiMac::GetDevice(), ns3::WifiMac::GetFrameExchangeManager(), GetSetupLinkIds(), ns3::WifiMacHeader::GetType(), ns3::WifiMacHeader::HasData(), IsAssociated(), ns3::WifiMacHeader::IsCtl(), ns3::WifiMacHeader::IsData(), ns3::WifiMacHeader::IsFromDs(), ns3::Mac48Address::IsGroup(), ns3::WifiMacHeader::IsQosAmsdu(), ns3::WifiMacHeader::IsQosData(), ns3::WifiMacHeader::IsToDs(), ns3::WifiMac::NotifyRxDrop(), NS_ASSERT, NS_LOG_FUNCTION, NS_LOG_LOGIC, ns3::WifiMac::Receive(), ReceiveAssocResp(), ReceiveBeacon(), ReceiveProbeResp(), ns3::WIFI_MAC_MGT_ASSOCIATION_REQUEST, ns3::WIFI_MAC_MGT_ASSOCIATION_RESPONSE, ns3::WIFI_MAC_MGT_BEACON, ns3::WIFI_MAC_MGT_PROBE_REQUEST, ns3::WIFI_MAC_MGT_PROBE_RESPONSE, ns3::WIFI_MAC_MGT_REASSOCIATION_REQUEST, and ns3::WIFI_MAC_MGT_REASSOCIATION_RESPONSE.
Process the (Re)Association Response frame received on the given link.
mpdu | the MPDU containing the (Re)Association Response frame |
linkId | the ID of the given link |
Definition at line 1020 of file sta-wifi-mac.cc.
References ns3::StaWifiMac::StaLinkEntity::apLinkId, ASSOCIATED, ns3::StaWifiMac::StaLinkEntity::bssid, ns3::EventId::Cancel(), ns3::WifiMacHeader::GetAddr2(), ns3::WifiMacHeader::GetAddr3(), ns3::MgtAssocResponseHeader::GetAssociationId(), GetLink(), ns3::WifiMac::GetMldAddress(), ns3::MgtAssocResponseHeader::GetMultiLinkElement(), ns3::WifiMac::GetNLinks(), ns3::MgtAssocResponseHeader::GetStatusCode(), ns3::WifiMac::GetWifiRemoteStationManager(), ns3::WifiMacHeader::IsAssocResp(), ns3::Callback< R, UArgs >::IsNull(), ns3::WifiMacHeader::IsReassocResp(), ns3::EventId::IsRunning(), ns3::StatusCode::IsSuccess(), m_aid, m_assocLogger, m_assocRequestEvent, ns3::WifiMac::m_linkUp, m_setupCompleted, m_state, NS_ABORT_MSG_IF, NS_ASSERT, NS_LOG_DEBUG, NS_LOG_FUNCTION, ns3::WifiMac::LinkEntity::phy, REFUSED, ns3::WifiMac::SetBssid(), ns3::WifiPhy::SetOffMode(), SetState(), StartScanning(), UpdateApInfo(), and WAIT_ASSOC_RESP.
Referenced by Receive().
Process the Beacon frame received on the given link.
mpdu | the MPDU containing the Beacon frame |
linkId | the ID of the given link |
Definition at line 933 of file sta-wifi-mac.cc.
References ASSOCIATED, ns3::StaWifiMac::StaLinkEntity::bssid, CheckSupportedRates(), ns3::SnrTag::Get(), ns3::WifiMacHeader::GetAddr2(), ns3::WifiMacHeader::GetAddr3(), ns3::MgtProbeResponseHeader::GetCapabilities(), GetCurrentChannel(), GetLink(), IsAssociated(), ns3::WifiMacHeader::IsBeacon(), ns3::CapabilityInformation::IsEss(), IsWaitAssocResp(), m_assocManager, m_beaconArrival, m_beaconInfo, ns3::StaWifiMac::ApInfo::m_bssid, ns3::StaWifiMac::ApInfo::m_frame, m_maxMissedBeacons, m_state, ns3::MicroSeconds(), ns3::Simulator::Now(), NS_ASSERT, NS_LOG_DEBUG, NS_LOG_FUNCTION, NS_LOG_LOGIC, RestartBeaconWatchdog(), and UpdateApInfo().
Referenced by Receive().
Process the Probe Response frame received on the given link.
mpdu | the MPDU containing the Probe Response frame |
linkId | the ID of the given link |
Definition at line 995 of file sta-wifi-mac.cc.
References CheckSupportedRates(), ns3::SnrTag::Get(), ns3::WifiMacHeader::GetAddr2(), ns3::WifiMacHeader::GetAddr3(), ns3::WifiMacHeader::IsProbeResp(), m_assocManager, ns3::StaWifiMac::ApInfo::m_bssid, NS_ASSERT, NS_LOG_DEBUG, and NS_LOG_FUNCTION.
Referenced by Receive().
|
private |
Restarts the beacon timer for the given link.
delay | the delay before the watchdog fires |
linkId | the ID of the given link |
Definition at line 693 of file sta-wifi-mac.cc.
References ns3::Simulator::GetDelayLeft(), GetLink(), max, MissedBeacons(), ns3::Simulator::Now(), NS_LOG_DEBUG, NS_LOG_FUNCTION, and ns3::Simulator::Schedule().
Referenced by ReceiveBeacon(), and ScanningTimeout().
void ns3::StaWifiMac::ScanningTimeout | ( | const std::optional< ApInfo > & | bestAp | ) |
This method is called after wait beacon timeout or wait probe request timeout has occurred.
This will trigger association process from beacons or probe responses gathered while scanning.
bestAp | the info about the best AP to associate with, if one was found |
Definition at line 538 of file sta-wifi-mac.cc.
References ns3::StaWifiMac::StaLinkEntity::apLinkId, ns3::StaWifiMac::StaLinkEntity::bssid, ns3::WifiRemoteStationManager::GetAffiliatedStaAddress(), GetLink(), ns3::WifiRemoteStationManager::GetMldAddress(), ns3::WifiMac::GetNLinks(), ns3::WifiMac::GetWifiRemoteStationManager(), m_maxMissedBeacons, ns3::MicroSeconds(), NS_ABORT_MSG, NS_ABORT_MSG_IF, NS_LOG_DEBUG, NS_LOG_FUNCTION, RestartBeaconWatchdog(), ns3::Seconds(), SendAssociationRequest(), ns3::StaWifiMac::StaLinkEntity::sendAssocReq, SetState(), StartScanning(), UpdateApInfo(), and WAIT_ASSOC_RESP.
Referenced by ns3::WifiAssocManager::ScanningTimeout().
|
private |
Forward an association or reassociation request packet to the DCF.
The standard is not clear on the correct queue for management frames if QoS is supported. We always use the DCF.
isReassoc | flag whether it is a reassociation request |
Definition at line 389 of file sta-wifi-mac.cc.
References ns3::Packet::AddHeader(), AssocRequestTimeout(), ns3::EventId::Cancel(), GetAssociationRequest(), ns3::WifiMac::GetBEQueue(), GetLink(), ns3::WifiMac::GetMldAddress(), GetMultiLinkElement(), ns3::WifiMac::GetNLinks(), ns3::WifiMac::GetQosSupported(), ns3::WifiMac::GetTxop(), ns3::WifiMac::GetVOQueue(), ns3::WifiMac::GetWifiRemoteStationManager(), ns3::EventId::IsRunning(), m_assocRequestEvent, m_assocRequestTimeout, NS_ABORT_MSG_IF, NS_LOG_FUNCTION, ns3::Txop::Queue(), ns3::Simulator::Schedule(), ns3::WifiMacHeader::SetAddr1(), ns3::WifiMacHeader::SetAddr2(), ns3::WifiMacHeader::SetAddr3(), ns3::WifiMacHeader::SetDsNotFrom(), ns3::WifiMacHeader::SetDsNotTo(), ns3::WifiMacHeader::SetType(), ns3::WIFI_MAC_MGT_ASSOCIATION_REQUEST, and ns3::WIFI_MAC_MGT_REASSOCIATION_REQUEST.
Referenced by AssocRequestTimeout(), PhyCapabilitiesChanged(), and ScanningTimeout().
void ns3::StaWifiMac::SendProbeRequest | ( | ) |
Forward a probe request packet to the DCF.
The standard is not clear on the correct queue for management frames if QoS is supported. We always use the DCF.
Definition at line 244 of file sta-wifi-mac.cc.
References ns3::Packet::AddHeader(), ns3::WifiMac::GetAddress(), ns3::Mac48Address::GetBroadcast(), ns3::WifiMac::GetEhtCapabilities(), ns3::WifiMac::GetEhtSupported(), ns3::WifiMac::GetExtendedCapabilities(), ns3::WifiMac::GetHeCapabilities(), ns3::WifiMac::GetHeSupported(), ns3::WifiMac::GetHtCapabilities(), ns3::WifiMac::GetHtSupported(), ns3::WifiMac::GetQosSupported(), ns3::WifiMac::GetSsid(), GetSupportedRates(), ns3::WifiMac::GetTxop(), ns3::WifiMac::GetVhtCapabilities(), ns3::WifiMac::GetVhtSupported(), ns3::WifiMac::GetVOQueue(), NS_LOG_FUNCTION, ns3::Txop::Queue(), ns3::WifiMacHeader::SetAddr1(), ns3::WifiMacHeader::SetAddr2(), ns3::WifiMacHeader::SetAddr3(), ns3::WifiMacHeader::SetDsNotFrom(), ns3::WifiMacHeader::SetDsNotTo(), ns3::MgtProbeRequestHeader::SetEhtCapabilities(), ns3::MgtProbeRequestHeader::SetExtendedCapabilities(), ns3::MgtProbeRequestHeader::SetHeCapabilities(), ns3::MgtProbeRequestHeader::SetHtCapabilities(), ns3::MgtProbeRequestHeader::SetSsid(), ns3::MgtProbeRequestHeader::SetSupportedRates(), ns3::WifiMacHeader::SetType(), ns3::MgtProbeRequestHeader::SetVhtCapabilities(), ns3::SINGLE_LINK_OP_ID, and ns3::WIFI_MAC_MGT_PROBE_REQUEST.
Referenced by ns3::WifiDefaultAssocManager::DoStartScanning().
|
private |
Enable or disable active probing.
enable | enable or disable active probing |
Definition at line 205 of file sta-wifi-mac.cc.
References m_activeProbing, m_state, NS_LOG_DEBUG, NS_LOG_FUNCTION, SCANNING, and StartScanning().
Referenced by GetTypeId().
void ns3::StaWifiMac::SetAssocManager | ( | Ptr< WifiAssocManager > | assocManager | ) |
Set the Association Manager.
assocManager | the Association Manager |
Definition at line 190 of file sta-wifi-mac.cc.
References m_assocManager, and NS_LOG_FUNCTION.
|
private |
Set the EDCA parameters.
ac | the access class |
cwMin | the minimum contention window size |
cwMax | the maximum contention window size |
aifsn | the number of slots that make up an AIFS |
txopLimit | the TXOP limit |
Definition at line 1418 of file sta-wifi-mac.cc.
References ns3::WifiMac::GetQosTxop(), ns3::Txop::SetAifsn(), ns3::Txop::SetMaxCw(), ns3::Txop::SetMinCw(), ns3::Txop::SetTxopLimit(), and ns3::SINGLE_LINK_OP_ID.
Referenced by UpdateApInfo().
|
private |
Set the MU EDCA parameters.
ac | the Access Category |
cwMin | the minimum contention window size |
cwMax | the maximum contention window size |
aifsn | the number of slots that make up an AIFS |
muEdcaTimer | the MU EDCA timer |
Definition at line 1432 of file sta-wifi-mac.cc.
References ns3::WifiMac::GetQosTxop(), ns3::QosTxop::SetMuAifsn(), ns3::QosTxop::SetMuCwMax(), ns3::QosTxop::SetMuCwMin(), ns3::QosTxop::SetMuEdcaTimer(), and ns3::SINGLE_LINK_OP_ID.
Referenced by UpdateApInfo().
|
private |
Set the current MAC state.
value | the new state |
Definition at line 1412 of file sta-wifi-mac.cc.
References m_state, and second::value.
Referenced by AssocRequestTimeout(), Disassociated(), AmpduAggregationTest::DoRun(), TwoLevelAggregationTest::DoRun(), HeAggregationTest::DoRunSubTest(), PhyCapabilitiesChanged(), ReceiveAssocResp(), ScanningTimeout(), and StartScanning().
phys | the physical layers attached to this MAC. |
Reimplemented from ns3::WifiMac.
Definition at line 223 of file sta-wifi-mac.cc.
References ns3::MakeCallback(), NS_LOG_FUNCTION, third::phy, PhyCapabilitiesChanged(), and ns3::WifiMac::SetWifiPhys().
Referenced by AmpduAggregationTest::DoRun(), TwoLevelAggregationTest::DoRun(), and HeAggregationTest::DoRunSubTest().
|
private |
Start the scanning process which trigger active or passive scanning based on the active probing flag.
Definition at line 505 of file sta-wifi-mac.cc.
References ns3::WifiScanParams::ACTIVE, third::channel, ns3::WifiScanParams::channelList, ns3::WifiMac::GetNLinks(), ns3::WifiPhy::GetPhyBand(), ns3::WifiMac::GetSsid(), ns3::RandomVariableStream::GetValue(), ns3::WifiMac::GetWifiPhy(), ns3::WifiPhy::HasFixedPhyBand(), m_activeProbing, m_assocManager, m_probeDelay, m_probeRequestTimeout, m_waitBeaconTimeout, ns3::WifiScanParams::maxChannelTime, ns3::MicroSeconds(), ns3::WifiScanParams::minChannelTime, NS_ASSERT, NS_LOG_FUNCTION, ns3::WifiScanParams::PASSIVE, ns3::WifiScanParams::probeDelay, SCANNING, SetState(), ns3::WifiScanParams::ssid, ns3::WifiScanParams::type, and ns3::WIFI_PHY_BAND_UNSPECIFIED.
Referenced by DoInitialize(), ReceiveAssocResp(), ScanningTimeout(), SetActiveProbing(), and TryToEnsureAssociated().
|
private |
Try to ensure that we are associated with an AP by taking an appropriate action depending on the current association status.
Definition at line 467 of file sta-wifi-mac.cc.
References ASSOCIATED, ns3::WifiMac::m_linkDown, m_state, NS_LOG_FUNCTION, REFUSED, SCANNING, StartScanning(), UNASSOCIATED, and WAIT_ASSOC_RESP.
Referenced by Disassociated(), and Enqueue().
|
private |
Update associated AP's information from the given management frame (Beacon, Probe Response or Association Response).
If STA is not associated, this information will be used for the association process.
frame | the body of the given management frame |
apAddr | MAC address of the AP |
bssid | MAC address of BSSID |
linkId | ID of the link the management frame was received over |
Definition at line 1189 of file sta-wifi-mac.cc.
References ns3::AC_BE, ns3::AC_BK, ns3::AC_VI, ns3::AC_VO, ns3::WifiRemoteStationManager::AddBasicMode(), ns3::WifiRemoteStationManager::AddStationEhtCapabilities(), ns3::WifiRemoteStationManager::AddStationHeCapabilities(), ns3::WifiRemoteStationManager::AddStationHtCapabilities(), ns3::WifiRemoteStationManager::AddStationVhtCapabilities(), ns3::WifiRemoteStationManager::AddSupportedMcs(), ns3::WifiRemoteStationManager::AddSupportedMode(), ns3::WifiMac::GetEhtSupported(), ns3::WifiMac::GetErpSupported(), ns3::WifiMac::GetHeConfiguration(), ns3::WifiMac::GetHeSupported(), ns3::WifiMac::GetHtSupported(), ns3::WifiPhy::GetModeList(), ns3::WifiMac::GetQosSupported(), ns3::WifiMac::GetVhtSupported(), ns3::WifiMac::GetWifiPhy(), ns3::WifiMac::GetWifiRemoteStationManager(), ns3::SupportedRates::IsBasicRate(), ns3::CapabilityInformation::IsShortPreamble(), ns3::CapabilityInformation::IsShortSlotTime(), ns3::SupportedRates::IsSupportedRate(), ns3::MicroSeconds(), NS_LOG_FUNCTION, ns3::WifiRemoteStationManager::RemoveAllSupportedMcs(), SetEdcaParameters(), SetMuEdcaParameters(), ns3::WifiRemoteStationManager::SetQosSupport(), ns3::WifiRemoteStationManager::SetShortPreambleEnabled(), ns3::WifiRemoteStationManager::SetShortSlotTimeEnabled(), ns3::WifiPhy::SetSlot(), ns3::WifiRemoteStationManager::SetUseNonErpProtection(), ns3::WIFI_MOD_CLASS_HE, and ns3::WIFI_MOD_CLASS_VHT.
Referenced by ReceiveAssocResp(), ReceiveBeacon(), and ScanningTimeout().
|
friend |
Allow test cases to access private members.
Definition at line 129 of file sta-wifi-mac.h.
|
friend |
Allow test cases to access private members.
Definition at line 131 of file sta-wifi-mac.h.
|
friend |
Allow test cases to access private members.
Definition at line 133 of file sta-wifi-mac.h.
|
friend |
Allow test cases to access private members.
Definition at line 127 of file sta-wifi-mac.h.
|
private |
active probing
Definition at line 493 of file sta-wifi-mac.h.
Referenced by GetActiveProbing(), SetActiveProbing(), and StartScanning().
|
private |
Association AID.
Definition at line 486 of file sta-wifi-mac.h.
Referenced by Disassociated(), GetAssociationId(), and ReceiveAssocResp().
|
private |
association logger
Definition at line 497 of file sta-wifi-mac.h.
Referenced by GetTypeId(), and ReceiveAssocResp().
|
private |
Association Manager.
Definition at line 487 of file sta-wifi-mac.h.
Referenced by DoDispose(), NotifyChannelSwitching(), ReceiveBeacon(), ReceiveProbeResp(), SetAssocManager(), and StartScanning().
|
private |
association request event
Definition at line 491 of file sta-wifi-mac.h.
Referenced by ReceiveAssocResp(), and SendAssociationRequest().
|
private |
association request timeout
Definition at line 490 of file sta-wifi-mac.h.
Referenced by GetTypeId(), and SendAssociationRequest().
|
private |
beacon arrival logger
Definition at line 501 of file sta-wifi-mac.h.
Referenced by GetTypeId(), and ReceiveBeacon().
|
private |
beacon info logger
Definition at line 502 of file sta-wifi-mac.h.
Referenced by GetTypeId(), and ReceiveBeacon().
|
private |
disassociation logger
Definition at line 499 of file sta-wifi-mac.h.
Referenced by Disassociated(), and GetTypeId().
|
private |
maximum missed beacons
Definition at line 492 of file sta-wifi-mac.h.
Referenced by GetTypeId(), ReceiveBeacon(), and ScanningTimeout().
|
private |
RandomVariable used to randomize the time of the first Probe Response on each channel.
Definition at line 494 of file sta-wifi-mac.h.
Referenced by AssignStreams(), GetTypeId(), and StartScanning().
|
private |
probe request timeout
Definition at line 489 of file sta-wifi-mac.h.
Referenced by GetTypeId(), and StartScanning().
|
private |
link setup canceled logger
Definition at line 500 of file sta-wifi-mac.h.
Referenced by Disassociated(), and GetTypeId().
|
private |
link setup completed logger
Definition at line 498 of file sta-wifi-mac.h.
Referenced by GetTypeId(), and ReceiveAssocResp().
|
private |
MAC state.
Definition at line 485 of file sta-wifi-mac.h.
Referenced by IsAssociated(), IsWaitAssocResp(), ReceiveAssocResp(), ReceiveBeacon(), SetActiveProbing(), SetState(), and TryToEnsureAssociated().
|
private |
wait beacon timeout
Definition at line 488 of file sta-wifi-mac.h.
Referenced by GetTypeId(), and StartScanning().