A Discrete-Event Network Simulator
API
net-device-queue-interface.cc
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2017 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 <stefano.avallone@.unina.it>
18  */
19 
21 
22 #include "queue-item.h"
23 #include "queue-limits.h"
24 
25 #include "ns3/abort.h"
26 #include "ns3/uinteger.h"
27 
28 namespace ns3
29 {
30 
31 NS_LOG_COMPONENT_DEFINE("NetDeviceQueueInterface");
32 
33 TypeId
35 {
36  static TypeId tid = TypeId("ns3::NetDeviceQueue")
37  .SetParent<Object>()
38  .SetGroupName("Network")
39  .AddConstructor<NetDeviceQueue>();
40  return tid;
41 }
42 
44  : m_stoppedByDevice(false),
45  m_stoppedByQueueLimits(false),
46  NS_LOG_TEMPLATE_DEFINE("NetDeviceQueueInterface")
47 {
48  NS_LOG_FUNCTION(this);
49 }
50 
52 {
53  NS_LOG_FUNCTION(this);
54 
55  m_queueLimits = nullptr;
57  m_device = nullptr;
58 }
59 
60 bool
62 {
63  NS_LOG_FUNCTION(this);
65 }
66 
67 void
69 {
70  NS_LOG_FUNCTION(this);
71  m_stoppedByDevice = false;
72 }
73 
74 void
76 {
77  NS_LOG_FUNCTION(this);
78  m_stoppedByDevice = true;
79 }
80 
81 void
83 {
84  NS_LOG_FUNCTION(this);
85 
86  bool wasStoppedByDevice = m_stoppedByDevice;
87  m_stoppedByDevice = false;
88 
89  // Request the queue disc to dequeue a packet
90  if (wasStoppedByDevice && !m_wakeCallback.IsNull())
91  {
93  }
94 }
95 
96 void
98 {
99  NS_LOG_FUNCTION(this << ndqi);
100 
101  m_device = ndqi->GetObject<NetDevice>();
102  NS_ABORT_MSG_IF(!m_device, "No NetDevice object was aggregated to the NetDeviceQueueInterface");
103 }
104 
105 void
107 {
108  m_wakeCallback = cb;
109 }
110 
111 void
113 {
114  NS_LOG_FUNCTION(this << bytes);
115  if (!m_queueLimits)
116  {
117  return;
118  }
119  m_queueLimits->Queued(bytes);
120  if (m_queueLimits->Available() >= 0)
121  {
122  return;
123  }
124  m_stoppedByQueueLimits = true;
125 }
126 
127 void
129 {
130  NS_LOG_FUNCTION(this << bytes);
131  if ((!m_queueLimits) || (!bytes))
132  {
133  return;
134  }
135  m_queueLimits->Completed(bytes);
136  if (m_queueLimits->Available() < 0)
137  {
138  return;
139  }
140  bool wasStoppedByQueueLimits = m_stoppedByQueueLimits;
141  m_stoppedByQueueLimits = false;
142  // Request the queue disc to dequeue a packet
143  if (wasStoppedByQueueLimits && !m_wakeCallback.IsNull())
144  {
145  m_wakeCallback();
146  }
147 }
148 
149 void
151 {
152  NS_LOG_FUNCTION(this);
153  if (!m_queueLimits)
154  {
155  return;
156  }
157  m_queueLimits->Reset();
158 }
159 
160 void
162 {
163  NS_LOG_FUNCTION(this << ql);
164  m_queueLimits = ql;
165 }
166 
169 {
170  NS_LOG_FUNCTION(this);
171  return m_queueLimits;
172 }
173 
175 
176 TypeId
178 {
179  static TypeId tid =
180  TypeId("ns3::NetDeviceQueueInterface")
181  .SetParent<Object>()
182  .SetGroupName("Network")
183  .AddConstructor<NetDeviceQueueInterface>()
184  .AddAttribute("TxQueuesType",
185  "The type of transmission queues to be used",
190  .AddAttribute("NTxQueues",
191  "The number of device transmission queues",
193  UintegerValue(1),
196  MakeUintegerChecker<uint16_t>(1, 65535));
197  return tid;
198 }
199 
201 {
202  NS_LOG_FUNCTION(this);
203 
204  // the default select queue callback returns 0
205  m_selectQueueCallback = [](Ptr<QueueItem> item) { return 0; };
206 }
207 
209 {
210  NS_LOG_FUNCTION(this);
211 }
212 
215 {
216  NS_ASSERT(i < m_txQueuesVector.size());
217  return m_txQueuesVector[i];
218 }
219 
220 std::size_t
222 {
223  return m_txQueuesVector.size();
224 }
225 
226 void
228 {
229  NS_LOG_FUNCTION(this);
230 
231  m_txQueuesVector.clear();
233 }
234 
235 void
237 {
238  NS_LOG_FUNCTION(this);
239 
240  // Notify the NetDeviceQueue objects that an object was aggregated
241  for (auto& tx : m_txQueuesVector)
242  {
243  tx->NotifyAggregatedObject(this);
244  }
246 }
247 
248 void
250 {
251  NS_LOG_FUNCTION(this << type);
252 
254  "Cannot call SetTxQueuesType after creating device queues");
255 
258 }
259 
260 void
262 {
263  NS_LOG_FUNCTION(this << numTxQueues);
264  NS_ASSERT(numTxQueues > 0);
265 
267  "Cannot call SetNTxQueues after creating device queues");
268 
269  // create the netdevice queues
270  for (std::size_t i = 0; i < numTxQueues; i++)
271  {
273  }
274 }
275 
276 void
278 {
280 }
281 
284 {
285  return m_selectQueueCallback;
286 }
287 
288 } // namespace ns3
void Nullify()
Discard the implementation, set it to null.
Definition: callback.h:575
bool IsNull() const
Check for null implementation.
Definition: callback.h:569
Network layer to device interface.
Definition: net-device.h:98
Network device transmission queue.
bool m_stoppedByQueueLimits
True if the queue has been stopped by a queue limits object.
virtual void Stop()
Called by the device to stop this device transmission queue.
void NotifyAggregatedObject(Ptr< NetDeviceQueueInterface > ndqi)
Notify this NetDeviceQueue that the NetDeviceQueueInterface was aggregated to an object.
Ptr< QueueLimits > GetQueueLimits()
Get queue limits to this queue.
Ptr< QueueLimits > m_queueLimits
Queue limits object.
virtual void Wake()
Called by the device to wake the queue disc associated with this device transmission queue.
virtual bool IsStopped() const
Get the status of the device transmission queue.
void SetQueueLimits(Ptr< QueueLimits > ql)
Set queue limits to this queue.
void ResetQueueLimits()
Reset queue limits state.
virtual void Start()
Called by the device to start this device transmission queue.
virtual void NotifyTransmittedBytes(uint32_t bytes)
Called by the netdevice to report the number of bytes it is going to transmit.
virtual void NotifyQueuedBytes(uint32_t bytes)
Called by the netdevice to report the number of bytes queued to the device queue.
Ptr< NetDevice > m_device
the netdevice aggregated to the NetDeviceQueueInterface
WakeCallback m_wakeCallback
Wake callback.
bool m_stoppedByDevice
True if the queue has been stopped by the device.
static TypeId GetTypeId()
Get the type ID.
virtual void SetWakeCallback(WakeCallback cb)
Set the wake callback.
Network device transmission queue interface.
SelectQueueCallback m_selectQueueCallback
Select queue callback.
std::vector< Ptr< NetDeviceQueue > > m_txQueuesVector
Device transmission queues.
std::size_t GetNTxQueues() const
Get the number of device transmission queues.
Ptr< NetDeviceQueue > GetTxQueue(std::size_t i) const
Get the i-th transmission queue of the device.
std::function< std::size_t(Ptr< QueueItem >)> SelectQueueCallback
Callback invoked to determine the tx queue selected for a given packet.
ObjectFactory m_txQueues
Device transmission queues TypeId.
void SetSelectQueueCallback(SelectQueueCallback cb)
Set the select queue callback.
void DoDispose() override
Dispose of the object.
SelectQueueCallback GetSelectQueueCallback() const
Get the select queue callback.
void SetTxQueuesType(TypeId type)
Set the type of device transmission queues to create.
void SetNTxQueues(std::size_t numTxQueues)
Set the number of device transmission queues to create.
void NotifyNewAggregate() override
Notify that an object was aggregated.
static TypeId GetTypeId()
Get the type ID.
Ptr< Object > Create() const
Create an Object instance of the configured TypeId.
void SetTypeId(TypeId tid)
Set the TypeId of the Objects to be created by this factory.
A base class which provides memory management and object aggregation.
Definition: object.h:89
friend class ObjectFactory
Friends.
Definition: object.h:328
virtual void NotifyNewAggregate()
Notify all Objects aggregated to this one of a new Object being aggregated.
Definition: object.cc:331
Ptr< T > GetObject() const
Get a pointer to the requested aggregated Object.
Definition: object.h:471
virtual void DoDispose()
Destructor implementation.
Definition: object.cc:352
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:77
a unique identifier for an interface.
Definition: type-id.h:59
@ ATTR_GET
The attribute can be read.
Definition: type-id.h:64
@ ATTR_CONSTRUCT
The attribute can be written at construction-time.
Definition: type-id.h:66
TypeId SetParent(TypeId tid)
Set the parent TypeId.
Definition: type-id.cc:931
Hold an unsigned integer type.
Definition: uinteger.h:45
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file,...
Definition: assert.h:66
#define NS_ABORT_MSG_IF(cond, msg)
Abnormal program termination if a condition is true, with a message.
Definition: abort.h:108
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:202
#define NS_LOG_TEMPLATE_DEFINE(name)
Initialize a reference to a Log component.
Definition: log.h:236
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system.
Definition: object-base.h:46
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Ptr< const AttributeChecker > MakeTypeIdChecker()
Definition: type-id.cc:1250
Ptr< const AttributeAccessor > MakeTypeIdAccessor(T1 a1)
Definition: type-id.h:598
Ptr< const AttributeAccessor > MakeUintegerAccessor(T1 a1)
Definition: uinteger.h:46