A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
wifi-tx-parameters.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2020 Universita' degli Studi di Napoli Federico II
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 * Author: Stefano Avallone <stavallo@unina.it>
18 */
19
20#ifndef WIFI_TX_PARAMETERS_H
21#define WIFI_TX_PARAMETERS_H
22
23#include "wifi-mac-header.h"
24#include "wifi-tx-vector.h"
25
26#include "ns3/nstime.h"
27
28#include <map>
29#include <memory>
30#include <set>
31
32namespace ns3
33{
34
35class WifiMpdu;
36struct WifiProtection;
37struct WifiAcknowledgment;
38
39/**
40 * \ingroup wifi
41 *
42 * This class stores the TX parameters (TX vector, protection mechanism,
43 * acknowledgment mechanism, TX duration, ...) for a frame of different types
44 * (MPDU, A-MPDU, multi-TID A-MPDU, MU PPDU, ...).
45 */
47{
48 public:
50 /**
51 * Copy constructor.
52 *
53 * \param txParams the WifiTxParameters to copy
54 */
55 WifiTxParameters(const WifiTxParameters& txParams);
56
57 /**
58 * Copy assignment operator.
59 * \param txParams the TX parameters to assign to this object
60 * \return the reference to this object
61 */
63
64 /**
65 * Move constructor. Must define it manually because copy constructor is explicit.
66 * \param txParams the WifiTxParameters to copy
67 */
68 WifiTxParameters(WifiTxParameters&& txParams) = default;
69
70 /**
71 * Move assignment operator. Must define it manually because copy assignment
72 * operator is explicit.
73 * \param txParams the TX parameters to assign to this object
74 * \return the reference to this object
75 */
77
78 WifiTxVector m_txVector; //!< TXVECTOR of the frame being prepared
79 std::unique_ptr<WifiProtection> m_protection; //!< protection method
80 std::unique_ptr<WifiAcknowledgment> m_acknowledgment; //!< acknowledgment method
81 Time m_txDuration{Time::Min()}; //!< TX duration of the frame
82
83 /**
84 * Reset the TX parameters.
85 */
86 void Clear();
87
88 /**
89 * Record that an MPDU is being added to the current frame. If an MPDU addressed
90 * to the same receiver already exists in the frame, A-MPDU aggregation is considered.
91 *
92 * \param mpdu the MPDU being added
93 */
95
96 /**
97 * Record that an MSDU is being aggregated to the last MPDU added to the frame
98 * that hase the same receiver.
99 *
100 * \param msdu the MSDU being aggregated
101 */
103
104 /**
105 * Get the size in bytes of the frame in case the given MPDU is added.
106 *
107 * \param mpdu the given MPDU
108 * \return the size in bytes of the frame in case the given MPDU is added
109 */
111
112 /**
113 * Get the size in bytes of the frame in case the given MSDU is aggregated.
114 *
115 * \param msdu the given MSDU
116 * \return a pair (size in bytes of the current A-MSDU, size in bytes of the frame)
117 in case the given MSDU is aggregated
118 */
119 std::pair<uint32_t, uint32_t> GetSizeIfAggregateMsdu(Ptr<const WifiMpdu> msdu) const;
120
121 /**
122 * Get the size in bytes of the (A-)MPDU addressed to the given receiver.
123 *
124 * \param receiver the MAC address of the given receiver
125 * \return the size in bytes of the (A-)MPDU addressed to the given receiver
126 */
127 uint32_t GetSize(Mac48Address receiver) const;
128
129 /// information about the frame being prepared for a specific receiver
130 struct PsduInfo
131 {
132 WifiMacHeader header; //!< MAC header of the last MPDU added
133 uint32_t amsduSize; //!< the size in bytes of the MSDU or A-MSDU
134 //!< included in the last MPDU added
135 uint32_t ampduSize; //!< the size in bytes of the A-MPDU if multiple
136 //!< MPDUs have been added, and zero otherwise
137 std::map<uint8_t, std::set<uint16_t>> seqNumbers; //!< set of the sequence numbers of the
138 //!< MPDUs added for each TID
139 };
140
141 /**
142 * Get a pointer to the information about the PSDU addressed to the given
143 * receiver, if present, and a null pointer otherwise.
144 *
145 * \param receiver the MAC address of the receiver
146 * \return a pointer to an entry in the PSDU information map or a null pointer
147 */
148 const PsduInfo* GetPsduInfo(Mac48Address receiver) const;
149
150 /// Map containing information about the PSDUs addressed to every receiver
151 typedef std::map<Mac48Address, PsduInfo> PsduInfoMap;
152
153 /**
154 * Get a const reference to the map containing information about PSDUs.
155 *
156 * \return a const reference to the map containing information about PSDUs
157 */
158 const PsduInfoMap& GetPsduInfoMap() const;
159
160 /**
161 * \brief Print the object contents.
162 * \param os output stream in which the data should be printed.
163 */
164 void Print(std::ostream& os) const;
165
166 private:
167 PsduInfoMap m_info; //!< information about the frame being prepared. Handles
168 //!< multi-TID A-MPDUs, MU PPDUs, etc.
169};
170
171/**
172 * \brief Stream insertion operator.
173 *
174 * \param os the output stream
175 * \param txParams the TX parameters
176 * \returns a reference to the stream
177 */
178std::ostream& operator<<(std::ostream& os, const WifiTxParameters* txParams);
179
180} // namespace ns3
181
182#endif /* WIFI_TX_PARAMETERS_H */
an EUI-48 address
Definition: mac48-address.h:46
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:77
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:105
static Time Min()
Minimum representable Time Not to be confused with Min(Time,Time).
Definition: nstime.h:287
Implements the IEEE 802.11 MAC header.
This class stores the TX parameters (TX vector, protection mechanism, acknowledgment mechanism,...
uint32_t GetSizeIfAddMpdu(Ptr< const WifiMpdu > mpdu) const
Get the size in bytes of the frame in case the given MPDU is added.
const PsduInfoMap & GetPsduInfoMap() const
Get a const reference to the map containing information about PSDUs.
WifiTxParameters & operator=(WifiTxParameters &&txParams)=default
Move assignment operator.
std::pair< uint32_t, uint32_t > GetSizeIfAggregateMsdu(Ptr< const WifiMpdu > msdu) const
Get the size in bytes of the frame in case the given MSDU is aggregated.
std::unique_ptr< WifiProtection > m_protection
protection method
WifiTxParameters & operator=(const WifiTxParameters &txParams)
Copy assignment operator.
uint32_t GetSize(Mac48Address receiver) const
Get the size in bytes of the (A-)MPDU addressed to the given receiver.
std::unique_ptr< WifiAcknowledgment > m_acknowledgment
acknowledgment method
const PsduInfo * GetPsduInfo(Mac48Address receiver) const
Get a pointer to the information about the PSDU addressed to the given receiver, if present,...
Time m_txDuration
TX duration of the frame.
WifiTxParameters(WifiTxParameters &&txParams)=default
Move constructor.
WifiTxVector m_txVector
TXVECTOR of the frame being prepared.
PsduInfoMap m_info
information about the frame being prepared.
void AggregateMsdu(Ptr< const WifiMpdu > msdu)
Record that an MSDU is being aggregated to the last MPDU added to the frame that hase the same receiv...
void Print(std::ostream &os) const
Print the object contents.
void AddMpdu(Ptr< const WifiMpdu > mpdu)
Record that an MPDU is being added to the current frame.
void Clear()
Reset the TX parameters.
std::map< Mac48Address, PsduInfo > PsduInfoMap
Map containing information about the PSDUs addressed to every receiver.
This class mimics the TXVECTOR which is to be passed to the PHY in order to define the parameters whi...
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:159
information about the frame being prepared for a specific receiver
std::map< uint8_t, std::set< uint16_t > > seqNumbers
set of the sequence numbers of the MPDUs added for each TID
uint32_t ampduSize
the size in bytes of the A-MPDU if multiple MPDUs have been added, and zero otherwise
WifiMacHeader header
MAC header of the last MPDU added.
uint32_t amsduSize
the size in bytes of the MSDU or A-MSDU included in the last MPDU added