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  void Print(std::ostream& os) const override;
42 
48  void SetVhtCapabilitiesInfo(uint32_t ctrl);
54  void SetSupportedMcsAndNssSet(uint64_t ctrl);
55 
61  uint32_t GetVhtCapabilitiesInfo() const;
67  uint64_t GetSupportedMcsAndNssSet() const;
68 
69  // Capabilities Info fields
75  void SetMaxMpduLength(uint16_t length);
81  void SetSupportedChannelWidthSet(uint8_t channelWidthSet);
87  void SetRxLdpc(uint8_t rxLdpc);
93  void SetShortGuardIntervalFor80Mhz(uint8_t shortGuardInterval);
99  void SetShortGuardIntervalFor160Mhz(uint8_t shortGuardInterval);
105  void SetRxStbc(uint8_t rxStbc);
111  void SetTxStbc(uint8_t txStbc);
117  void SetMaxAmpduLength(uint32_t maxAmpduLength);
118 
124  uint16_t GetMaxMpduLength() const;
130  uint8_t GetSupportedChannelWidthSet() const;
136  uint8_t GetRxLdpc() const;
142  uint8_t GetRxStbc() const;
148  uint8_t GetTxStbc() const;
149 
154  void SetRxMcsMap(uint8_t mcs, uint8_t nss);
159  void SetTxMcsMap(uint8_t mcs, uint8_t nss);
165  void SetRxHighestSupportedLgiDataRate(uint16_t supportedDatarate);
171  void SetTxHighestSupportedLgiDataRate(uint16_t supportedDatarate);
179  bool IsSupportedMcs(uint8_t mcs, uint8_t nss) const;
180 
186  uint16_t GetRxHighestSupportedLgiDataRate() const;
187 
194  bool IsSupportedTxMcs(uint8_t mcs) const;
201  bool IsSupportedRxMcs(uint8_t mcs) const;
202 
208  uint32_t GetMaxAmpduLength() const;
209 
210  private:
211  uint16_t GetInformationFieldSize() const override;
212  void SerializeInformationField(Buffer::Iterator start) const override;
213  uint16_t DeserializeInformationField(Buffer::Iterator start, uint16_t length) override;
214 
215  // Capabilities Info fields
216  uint8_t m_maxMpduLength;
218  uint8_t m_rxLdpc;
221  uint8_t m_txStbc;
222  uint8_t m_rxStbc;
229  uint8_t m_vhtTxopPs;
230  uint8_t m_htcVhtCapable;
235 
236  // MCS and NSS field information
237  std::vector<uint8_t> m_rxMcsMap;
240  std::vector<uint8_t> m_txMcsMap;
243 };
244 
245 } // namespace ns3
246 
247 #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.
void Print(std::ostream &os) const override
Generate human-readable form of IE.
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.
uint8_t WifiInformationElementId
This type is used to represent an Information Element ID.