A Discrete-Event Network Simulator
API
vht-capabilities.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2015
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License version 2 as
6  * published by the Free Software Foundation;
7  *
8  * This program is distributed in the hope that it will be useful,
9  * but WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11  * GNU General Public License for more details.
12  *
13  * You should have received a copy of the GNU General Public License
14  * along with this program; if not, write to the Free Software
15  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16  *
17  * Authors: Ghada Badawy <gbadawy@gmail.com>
18  * Sébastien Deronne <sebastien.deronne@gmail.com>
19  */
20 
21 #ifndef VHT_CAPABILITIES_H
22 #define VHT_CAPABILITIES_H
23 
24 #include "ns3/wifi-information-element.h"
25 
26 namespace ns3
27 {
28 
35 {
36  public:
38 
39  // Implementations of pure virtual methods of WifiInformationElement
40  WifiInformationElementId ElementId() const override;
41 
47  void SetVhtCapabilitiesInfo(uint32_t ctrl);
53  void SetSupportedMcsAndNssSet(uint64_t ctrl);
54 
60  uint32_t GetVhtCapabilitiesInfo() const;
66  uint64_t GetSupportedMcsAndNssSet() const;
67 
68  // Capabilities Info fields
74  void SetMaxMpduLength(uint16_t length);
80  void SetSupportedChannelWidthSet(uint8_t channelWidthSet);
86  void SetRxLdpc(uint8_t rxLdpc);
92  void SetShortGuardIntervalFor80Mhz(uint8_t shortGuardInterval);
98  void SetShortGuardIntervalFor160Mhz(uint8_t shortGuardInterval);
104  void SetRxStbc(uint8_t rxStbc);
110  void SetTxStbc(uint8_t txStbc);
116  void SetMaxAmpduLength(uint32_t maxAmpduLength);
117 
123  uint16_t GetMaxMpduLength() const;
129  uint8_t GetSupportedChannelWidthSet() const;
135  uint8_t GetRxLdpc() const;
141  uint8_t GetRxStbc() const;
147  uint8_t GetTxStbc() const;
148 
153  void SetRxMcsMap(uint8_t mcs, uint8_t nss);
158  void SetTxMcsMap(uint8_t mcs, uint8_t nss);
164  void SetRxHighestSupportedLgiDataRate(uint16_t supportedDatarate);
170  void SetTxHighestSupportedLgiDataRate(uint16_t supportedDatarate);
178  bool IsSupportedMcs(uint8_t mcs, uint8_t nss) const;
179 
185  uint16_t GetRxHighestSupportedLgiDataRate() const;
186 
193  bool IsSupportedTxMcs(uint8_t mcs) const;
200  bool IsSupportedRxMcs(uint8_t mcs) const;
201 
207  uint32_t GetMaxAmpduLength() const;
208 
209  private:
210  uint16_t GetInformationFieldSize() const override;
211  void SerializeInformationField(Buffer::Iterator start) const override;
212  uint16_t DeserializeInformationField(Buffer::Iterator start, uint16_t length) override;
213 
214  // Capabilities Info fields
215  uint8_t m_maxMpduLength;
217  uint8_t m_rxLdpc;
220  uint8_t m_txStbc;
221  uint8_t m_rxStbc;
228  uint8_t m_vhtTxopPs;
229  uint8_t m_htcVhtCapable;
234 
235  // MCS and NSS field information
236  std::vector<uint8_t> m_rxMcsMap;
239  std::vector<uint8_t> m_txMcsMap;
242 };
243 
252 std::ostream& operator<<(std::ostream& os, const VhtCapabilities& vhtCapabilities);
253 
254 } // namespace ns3
255 
256 #endif /* VHT_CAPABILITY_H */
iterator in a Buffer instance
Definition: buffer.h:100
The IEEE 802.11ac VHT Capabilities.
uint8_t m_htcVhtCapable
HTC VHT capable.
void SetRxHighestSupportedLgiDataRate(uint16_t supportedDatarate)
Set the receive highest supported LGI data rate.
uint16_t GetInformationFieldSize() const override
Length of serialized information (i.e., the length of the body of the IE, not including the Element I...
void SetVhtCapabilitiesInfo(uint32_t ctrl)
Set the VHT Capabilities Info field in the VHT Capabilities information element.
bool IsSupportedMcs(uint8_t mcs, uint8_t nss) const
Get the is MCS supported.
void SetSupportedChannelWidthSet(uint8_t channelWidthSet)
Set the supported channel width set.
void SetMaxMpduLength(uint16_t length)
Set the maximum MPDU length.
uint32_t GetMaxAmpduLength() const
Return the maximum A-MPDU length.
uint8_t m_shortGuardIntervalFor80Mhz
short guard interval for 80 MHz
uint8_t GetSupportedChannelWidthSet() const
Get the supported channel width set.
uint16_t DeserializeInformationField(Buffer::Iterator start, uint16_t length) override
Deserialize information (i.e., the body of the IE, not including the Element ID and length octets)
uint8_t m_vhtLinkAdaptationCapable
VHT link adaptation capable.
void SetRxLdpc(uint8_t rxLdpc)
Set the receive LDPC.
void SerializeInformationField(Buffer::Iterator start) const override
Serialize information (i.e., the body of the IE, not including the Element ID and length octets)
void SetTxStbc(uint8_t txStbc)
Set the transmit STBC.
uint8_t GetRxStbc() const
Get the receive STBC.
uint8_t m_muBeamformerCapable
MU beamformer capable.
bool IsSupportedTxMcs(uint8_t mcs) const
Returns true if transmit MCS is supported.
void SetTxMcsMap(uint8_t mcs, uint8_t nss)
uint8_t m_muBeamformeeCapable
MU beamformee capable.
uint8_t m_vhtTxopPs
VHT TXOP PS.
void SetShortGuardIntervalFor80Mhz(uint8_t shortGuardInterval)
Set the short guard interval 80 MHz.
uint8_t m_txStbc
transmit STBC
std::vector< uint8_t > m_txMcsMap
transmit MCS map
bool IsSupportedRxMcs(uint8_t mcs) const
Returns true if receive MCS is supported.
uint8_t m_suBeamformerCapable
SU beamformer capable.
uint8_t m_rxStbc
receive STBC
uint8_t m_maxMpduLength
maximum MPDU length
uint16_t GetMaxMpduLength() const
Get the maximum MPDU length.
uint16_t m_txHighestSupportedLongGuardIntervalDataRate
transmit highest supported long guard interval data rate
uint8_t GetTxStbc() const
Get the transmit STBC.
uint16_t GetRxHighestSupportedLgiDataRate() const
Get the receive highest supported LGI data rate.
uint16_t m_rxHighestSupportedLongGuardIntervalDataRate
receive highest supported long guard interval data rate
WifiInformationElementId ElementId() const override
Get the wifi information element ID.
uint8_t m_supportedChannelWidthSet
supported channel width set
uint8_t m_shortGuardIntervalFor160Mhz
short guard interval for 160 MHz
std::vector< uint8_t > m_rxMcsMap
receive MCS map
uint8_t m_suBeamformeeCapable
SU beamformee capable.
uint8_t m_beamformeeStsCapable
beamformee STS capable
uint64_t GetSupportedMcsAndNssSet() const
Return the MCS and NSS field in the VHT Capabilities information element.
void SetTxHighestSupportedLgiDataRate(uint16_t supportedDatarate)
Set the transmit highest supported LGI data rate.
uint32_t GetVhtCapabilitiesInfo() const
Return the VHT Capabilities Info field in the VHT Capabilities information element.
uint8_t m_rxAntennaPatternConsistency
receive antenna pattern consistency
uint8_t m_rxLdpc
receive LDPC
void SetShortGuardIntervalFor160Mhz(uint8_t shortGuardInterval)
Set the short guard interval 160 MHz.
uint8_t m_txAntennaPatternConsistency
transmit antenna pattern consistency
void SetMaxAmpduLength(uint32_t maxAmpduLength)
Set the maximum AMPDU length.
uint8_t m_numberOfSoundingDimensions
number of sounding dimensions
void SetSupportedMcsAndNssSet(uint64_t ctrl)
Set the MCS and NSS field in the VHT Capabilities information element.
void SetRxMcsMap(uint8_t mcs, uint8_t nss)
uint8_t m_maxAmpduLengthExponent
maximum A-MPDU length exponent
uint8_t GetRxLdpc() const
Get the receive LDPC.
void SetRxStbc(uint8_t rxStbc)
Set the receive STBC.
Information element, as defined in 802.11-2007 standard.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
std::ostream & operator<<(std::ostream &os, const Angles &a)
Definition: angles.cc:129
uint8_t WifiInformationElementId
This type is used to represent an Information Element ID.