A Discrete-Event Network Simulator
API
vht-operation.h
Go to the documentation of this file.
1/* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
2/*
3 * Copyright (c) 2016 Sébastien Deronne
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation;
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 *
18 * Author: Sébastien Deronne <sebastien.deronne@gmail.com>
19 */
20
21#ifndef VHT_OPERATION_H
22#define VHT_OPERATION_H
23
24#include "ns3/wifi-information-element.h"
25
26namespace ns3 {
27
36{
37public:
38 VhtOperation ();
39
40 // Implementations of pure virtual methods of WifiInformationElement
41 WifiInformationElementId ElementId () const override;
42 uint8_t GetInformationFieldSize () const override;
44 uint8_t DeserializeInformationField (Buffer::Iterator start, uint8_t length) override;
45 /* This information element is a bit special in that it is only
46 included if the STA is a VHT STA. To support this we
47 override the Serialize and GetSerializedSize methods of
48 WifiInformationElement. */
50 uint16_t GetSerializedSize () const override;
51
57 void SetVhtSupported (uint8_t vhtSupported);
58
64 void SetChannelWidth (uint8_t channelWidth);
70 void SetChannelCenterFrequencySegment0 (uint8_t channelCenterFrequencySegment0);
76 void SetChannelCenterFrequencySegment1 (uint8_t channelCenterFrequencySegment1);
82 void SetBasicVhtMcsAndNssSet (uint16_t basicVhtMcsAndNssSet);
90 void SetMaxVhtMcsPerNss (uint8_t nss, uint8_t maxVhtMcs);
91
97 uint8_t GetChannelWidth (void) const;
103 uint8_t GetChannelCenterFrequencySegment0 (void) const;
109 uint8_t GetChannelCenterFrequencySegment1 (void) const;
115 uint16_t GetBasicVhtMcsAndNssSet (void) const;
116
117
118private:
119 //VHT Operation Information
123
124 //Basic VHT-MCS and NSS Set
126
129};
130
139std::ostream &operator << (std::ostream &os, const VhtOperation &VhtOperation);
140
141} //namespace ns3
142
143#endif /* VHT_OPERATION_H */
iterator in a Buffer instance
Definition: buffer.h:99
The VHT Operation Information Element.
Definition: vht-operation.h:36
uint16_t m_basicVhtMcsAndNssSet
basic VHT MCS NSS set
uint8_t m_channelWidth
channel width
void SetVhtSupported(uint8_t vhtSupported)
Set the VHT supported information element.
uint8_t GetInformationFieldSize() const override
Length of serialized information (i.e., the length of the body of the IE, not including the Element I...
uint16_t GetBasicVhtMcsAndNssSet(void) const
Return the Basic VHT-MCS And Nss field in the VHT Operation information element.
uint8_t GetChannelCenterFrequencySegment0(void) const
Return the Channel Center Frequency Segment 0 field in the VHT Operation information element.
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 SetMaxVhtMcsPerNss(uint8_t nss, uint8_t maxVhtMcs)
Set the Basic VHT-MCS and NSS field in the VHT Operation information element by specifying the tuple ...
uint8_t m_channelCenterFrequencySegment1
channel center frequency segment 1
uint8_t GetChannelWidth(void) const
Return the Channel Width field in the VHT Operation information element.
uint16_t GetSerializedSize() const override
Get the size of the serialized IE including Element ID and length fields.
Buffer::Iterator Serialize(Buffer::Iterator start) const override
Serialize entire IE including Element ID and length fields.
uint8_t m_channelCenterFrequencySegment0
channel center frequency segment 0
uint8_t DeserializeInformationField(Buffer::Iterator start, uint8_t length) override
Deserialize information (i.e., the body of the IE, not including the Element ID and length octets)
void SetBasicVhtMcsAndNssSet(uint16_t basicVhtMcsAndNssSet)
Set the Basic VHT-MCS and NSS field in the VHT Operation information element.
uint8_t m_vhtSupported
This is used to decide whether this element should be added to the frame or not.
WifiInformationElementId ElementId() const override
void SetChannelWidth(uint8_t channelWidth)
Set the Channel Width field in the VHT Operation information element.
uint8_t GetChannelCenterFrequencySegment1(void) const
Return the Channel Center Frequency Segment 1 field in the VHT Operation information element.
void SetChannelCenterFrequencySegment1(uint8_t channelCenterFrequencySegment1)
Set the Channel Center Frequency Segment 1 field in the VHT Operation information element.
void SetChannelCenterFrequencySegment0(uint8_t channelCenterFrequencySegment0)
Set the Channel Center Frequency Segment 0 field in the VHT Operation information element.
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:139
uint8_t WifiInformationElementId
This type is used to represent an Information Element ID.
def start()
Definition: core.py:1853