A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
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
28namespace ns3
29{
30
31NS_LOG_COMPONENT_DEFINE("NetDeviceQueueInterface");
32
33TypeId
35{
36 static TypeId tid = TypeId("ns3::NetDeviceQueue")
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
60bool
62{
63 NS_LOG_FUNCTION(this);
65}
66
67void
69{
70 NS_LOG_FUNCTION(this);
71 m_stoppedByDevice = false;
72}
73
74void
76{
77 NS_LOG_FUNCTION(this);
78 m_stoppedByDevice = true;
79}
80
81void
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
96void
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
105void
107{
108 m_wakeCallback = cb;
109}
110
111void
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 }
125}
126
127void
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;
142 // Request the queue disc to dequeue a packet
143 if (wasStoppedByQueueLimits && !m_wakeCallback.IsNull())
144 {
146 }
147}
148
149void
151{
152 NS_LOG_FUNCTION(this);
153 if (!m_queueLimits)
154 {
155 return;
156 }
157 m_queueLimits->Reset();
158}
159
160void
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
176TypeId
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
220std::size_t
222{
223 return m_txQueuesVector.size();
224}
225
226void
228{
229 NS_LOG_FUNCTION(this);
230
231 m_txQueuesVector.clear();
233}
234
235void
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
248void
250{
251 NS_LOG_FUNCTION(this << type);
252
254 "Cannot call SetTxQueuesType after creating device queues");
255
257 m_txQueues.SetTypeId(type);
258}
259
260void
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
276void
278{
280}
281
284{
286}
287
288} // namespace ns3
void Nullify()
Discard the implementation, set it to null.
Definition: callback.h:577
bool IsNull() const
Check for null implementation.
Definition: callback.h:571
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:368
virtual void NotifyNewAggregate()
Notify all Objects aggregated to this one of a new Object being aggregated.
Definition: object.cc:423
Ptr< T > GetObject() const
Get a pointer to the requested aggregated Object.
Definition: object.h:522
virtual void DoDispose()
Destructor implementation.
Definition: object.cc:444
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:932
AttributeValue implementation for TypeId.
Definition: type-id.h:598
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
Ptr< const AttributeChecker > MakeTypeIdChecker()
Definition: type-id.cc:1251
Ptr< const AttributeAccessor > MakeTypeIdAccessor(T1 a1)
Definition: type-id.h:598
Ptr< const AttributeAccessor > MakeUintegerAccessor(T1 a1)
Definition: uinteger.h:46
#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.