/usr/include/ns3.27/ns3/traffic-control-layer.h is in libns3-dev 3.27+dfsg-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 | /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
/*
* Copyright (c) 2015 Natale Patriciello <natale.patriciello@gmail.com>
* 2016 Stefano Avallone <stavallo@unina.it>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation;
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#ifndef TRAFFICCONTROLLAYER_H
#define TRAFFICCONTROLLAYER_H
#include "ns3/object.h"
#include "ns3/address.h"
#include "ns3/net-device.h"
#include "ns3/node.h"
#include "ns3/queue-item.h"
#include <map>
#include <vector>
namespace ns3 {
class Packet;
class QueueDisc;
class NetDeviceQueueInterface;
/**
* \defgroup traffic-control
*
* The Traffic Control layer aims at introducing an equivalent of the Linux Traffic
* Control infrastructure into ns-3. The Traffic Control layer sits in between
* the NetDevices (L2) and any network protocol (e.g., IP). It is in charge of
* processing packets and performing actions on them: scheduling, dropping,
* marking, policing, etc.
*
* \ingroup traffic-control
*
* \brief Traffic control layer class
*
* This object represents the main interface of the Traffic Control Module.
* Basically, we manage both IN and OUT directions (sometimes called RX and TX,
* respectively). The OUT direction is easy to follow, since it involves
* direct calls: upper layer (e.g. IP) calls the Send method on an instance of
* this class, which then calls the Enqueue method of the QueueDisc associated
* with the device. The Dequeue method of the QueueDisc finally calls the Send
* method of the NetDevice.
*
* The IN direction uses a little trick to reduce dependencies between modules.
* In simple words, we use Callbacks to connect upper layer (which should register
* their Receive callback through RegisterProtocolHandler) and NetDevices.
*
* An example of the IN connection between this layer and IP layer is the following:
*\verbatim
Ptr<TrafficControlLayer> tc = m_node->GetObject<TrafficControlLayer> ();
NS_ASSERT (tc != 0);
m_node->RegisterProtocolHandler (MakeCallback (&TrafficControlLayer::Receive, tc),
Ipv4L3Protocol::PROT_NUMBER, device);
m_node->RegisterProtocolHandler (MakeCallback (&TrafficControlLayer::Receive, tc),
ArpL3Protocol::PROT_NUMBER, device);
tc->RegisterProtocolHandler (MakeCallback (&Ipv4L3Protocol::Receive, this),
Ipv4L3Protocol::PROT_NUMBER, device);
tc->RegisterProtocolHandler (MakeCallback (&ArpL3Protocol::Receive, PeekPointer (GetObject<ArpL3Protocol> ())),
ArpL3Protocol::PROT_NUMBER, device);
\endverbatim
* On the node, for IPv4 and ARP packet, is registered the
* TrafficControlLayer::Receive callback. At the same time, on the TrafficControlLayer
* object, is registered the callbacks associated to the upper layers (IPv4 or ARP).
*
* When the node receives an IPv4 or ARP packet, it calls the Receive method
* on TrafficControlLayer, that calls the right upper-layer callback once it
* finishes the operations on the packet received.
*
* Discrimination through callbacks (in other words: what is the right upper-layer
* callback for this packet?) is done through checks over the device and the
* protocol number.
*/
class TrafficControlLayer : public Object
{
public:
/**
* \brief Get the type ID.
* \return the object TypeId
*/
static TypeId GetTypeId (void);
/**
* \brief Get the type ID for the instance
* \return the instance TypeId
*/
virtual TypeId GetInstanceTypeId (void) const;
/**
* \brief Constructor
*/
TrafficControlLayer ();
virtual ~TrafficControlLayer ();
/**
* \brief Register an IN handler
*
* The handler will be invoked when a packet is received to pass it to
* upper layers.
*
* \param handler the handler to register
* \param protocolType the type of protocol this handler is
* interested in. This protocol type is a so-called
* EtherType, as registered here:
* http://standards.ieee.org/regauth/ethertype/eth.txt
* the value zero is interpreted as matching all
* protocols.
* \param device the device attached to this handler. If the
* value is zero, the handler is attached to all
* devices.
*/
void RegisterProtocolHandler (Node::ProtocolHandler handler,
uint16_t protocolType,
Ptr<NetDevice> device);
/// Typedef for queue disc vector
typedef std::vector<Ptr<QueueDisc> > QueueDiscVector;
/**
* \brief Perform the operations that the traffic control layer needs to do when
* an IPv4/v6 interface is added to a device
* \param device the device which the IPv4/v6 interface has been added to
*
* This method creates a NetDeviceQueueInterface for the device
*/
virtual void SetupDevice (Ptr<NetDevice> device);
/**
* \brief This method can be used to set the root queue disc installed on a device
*
* \param device the device on which the provided queue disc will be installed
* \param qDisc the queue disc to be installed as root queue disc on device
*/
virtual void SetRootQueueDiscOnDevice (Ptr<NetDevice> device, Ptr<QueueDisc> qDisc);
/**
* \brief This method can be used to get the root queue disc installed on a device
*
* \param device the device on which the requested root queue disc is installed
* \return the root queue disc installed on the given device
*/
virtual Ptr<QueueDisc> GetRootQueueDiscOnDevice (Ptr<NetDevice> device) const;
/**
* \brief This method can be used to remove the root queue disc (and associated
* filters, classes and queues) installed on a device
*
* \param device the device on which the installed queue disc will be deleted
*/
virtual void DeleteRootQueueDiscOnDevice (Ptr<NetDevice> device);
/**
* \brief Set node associated with this stack.
* \param node node to set
*/
void SetNode (Ptr<Node> node);
/**
* \brief Called by NetDevices, incoming packet
*
* After analyses and scheduling, this method will call the right handler
* to pass the packet up in the stack.
*
* \param device network device
* \param p the packet
* \param protocol next header value
* \param from address of the correspondant
* \param to address of the destination
* \param packetType type of the packet
*/
virtual void Receive (Ptr<NetDevice> device, Ptr<const Packet> p,
uint16_t protocol, const Address &from,
const Address &to, NetDevice::PacketType packetType);
/**
* \brief Called from upper layer to queue a packet for the transmission.
*
* \param device the device the packet must be sent to
* \param item a queue item including a packet and additional information
*/
virtual void Send (Ptr<NetDevice> device, Ptr<QueueDiscItem> item);
/// Callback invoked to determine the tx queue selected for a given packet
typedef Callback< uint8_t, Ptr<QueueItem> > SelectQueueCallback;
protected:
virtual void DoDispose (void);
virtual void DoInitialize (void);
virtual void NotifyNewAggregate (void);
private:
/**
* \brief Copy constructor
* Disable default implementation to avoid misuse
*/
TrafficControlLayer (TrafficControlLayer const &);
/**
* \brief Assignment operator
* \return this object
* Disable default implementation to avoid misuse
*/
TrafficControlLayer& operator= (TrafficControlLayer const &);
/**
* \brief Protocol handler entry.
* This structure is used to demultiplex all the protocols.
*/
struct ProtocolHandlerEntry {
Node::ProtocolHandler handler; //!< the protocol handler
Ptr<NetDevice> device; //!< the NetDevice
uint16_t protocol; //!< the protocol number
bool promiscuous; //!< true if it is a promiscuous handler
};
/**
* \brief Information to store for each device
*/
class NetDeviceInfo
{
public:
/**
* \brief Constructor
*
* \param rootQueueDisc the root queue disc installed on the device
* \param ndqi the NetDeviceQueueInterface aggregated to the device
* \param queueDiscsToWake the vector of queue discs to wake
* \param selectQueueCallback the select queue callback
*/
NetDeviceInfo (Ptr<QueueDisc> rootQueueDisc, Ptr<NetDeviceQueueInterface> ndqi,
QueueDiscVector queueDiscsToWake, SelectQueueCallback selectQueueCallback);
virtual ~NetDeviceInfo ();
Ptr<QueueDisc> m_rootQueueDisc; //!< the root queue disc on the device
Ptr<NetDeviceQueueInterface> m_ndqi; //!< the netdevice queue interface
QueueDiscVector m_queueDiscsToWake; //!< the vector of queue discs to wake
SelectQueueCallback m_selectQueueCallback; //!< the select queue callback
private:
NetDeviceInfo ();
/**
* \brief Copy constructor
* Disable default implementation to avoid misuse
*/
NetDeviceInfo (NetDeviceInfo const &);
/**
* \brief Assignment operator
* \return this object
* Disable default implementation to avoid misuse
*/
NetDeviceInfo& operator= (NetDeviceInfo const &);
};
/// Typedef for protocol handlers container
typedef std::vector<struct ProtocolHandlerEntry> ProtocolHandlerList;
/**
* \brief Required by the object map accessor
* \return the number of devices in the m_netDevices map
*/
uint32_t GetNDevices (void) const;
/**
* \brief Required by the object map accessor
* \param index the index of the device in the node's device list
* \return the root queue disc installed on the specified device
*/
Ptr<QueueDisc> GetRootQueueDiscOnDeviceByIndex (uint32_t index) const;
/// The node this TrafficControlLayer object is aggregated to
Ptr<Node> m_node;
/// Map storing the required information for each device with a queue disc installed
std::map<Ptr<NetDevice>, NetDeviceInfo> m_netDevices;
ProtocolHandlerList m_handlers; //!< List of upper-layer handlers
};
} // namespace ns3
#endif // TRAFFICCONTROLLAYER_H
|