|
A Discrete-Event Network Simulator
|
API
|
Go to the documentation of this file.
23 #include "ns3/object.h"
24 #include "ns3/traced-value.h"
25 #include "ns3/traced-callback.h"
26 #include "ns3/queue-item.h"
27 #include "ns3/queue-size.h"
37 template <
typename Item>
class Queue;
38 class NetDeviceQueueInterface;
267 void Print (std::ostream &os)
const;
379 virtual void SetQuota (
const uint32_t quota);
385 virtual uint32_t
GetQuota (
void)
const;
QueueDisc & operator=(const QueueDisc &o)
Assignment operator.
a unique identifier for an interface.
void RunEnd(void)
Modelled after the Linux function qdisc_run_end (include/net/sch_generic.h).
std::map< std::string, uint32_t > nDroppedPacketsBeforeEnqueue
Packets dropped before enqueue, for each reason.
QueueDiscSizePolicy
Enumeration of the available policies to handle the queue disc size.
std::map< std::string, uint32_t > nDroppedPacketsAfterDequeue
Packets dropped after dequeue, for each reason.
@ MULTIPLE_QUEUES
Used by queue discs with multiple internal queues/child queue discs.
virtual bool CheckConfig(void)=0
Check whether the current configuration is correct.
virtual uint32_t GetQuota(void) const
Get the maximum number of dequeue operations following a packet enqueue.
TracedCallback< Time > m_sojourn
Sojourn time of the latest dequeued packet.
Structure that keeps the queue disc statistics.
static constexpr const char * CHILD_QUEUE_DISC_MARK
Packet marked by a child queue disc.
void Run(void)
Modelled after the Linux function __qdisc_run (net/sched/sch_generic.c) Dequeues multiple packets,...
uint32_t nTotalMarkedPackets
Total marked packets.
Queue< QueueDiscItem > InternalQueue
Internal queues store QueueDiscItem objects.
uint32_t m_quota
Maximum number of packets dequeued in a qdisc run.
static TypeId GetTypeId(void)
Get the type ID.
TracedCallback< Ptr< const QueueDiscItem > > m_traceEnqueue
Traced callback: fired when a packet is enqueued.
bool SetMaxSize(QueueSize size)
Set the maximum size of the queue disc.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
std::function< void(Ptr< const QueueDiscItem >)> InternalQueueDropFunctor
Type for the function objects notifying that a packet has been dropped by an internal queue.
uint32_t nTotalRequeuedPackets
Total requeued packets.
Ptr< QueueDisc > GetQueueDisc(void) const
Get the queue disc attached to this class.
QueueDisc is an abstract base class providing the interface and implementing the operations common to...
QueueSize GetMaxSize(void) const
Get the maximum size of the queue disc.
uint32_t nTotalDequeuedPackets
Total dequeued packets.
Ptr< QueueDiscClass > GetQueueDiscClass(std::size_t i) const
Get the i-th queue disc class.
Ptr< QueueDisc > m_queueDisc
Queue disc attached to this class.
uint32_t nTotalDroppedPackets
Total dropped packets.
bool Enqueue(Ptr< QueueDiscItem > item)
Pass a packet to store to the queue discipline.
uint32_t nTotalSentPackets
Total sent packets – this value is not kept up to date, call GetStats first.
std::vector< Ptr< PacketFilter > > m_filters
Packet filters.
Ptr< PacketFilter > GetPacketFilter(std::size_t i) const
Get the i-th packet filter.
@ NO_LIMITS
Used by queue discs with unlimited size.
static TypeId GetTypeId(void)
Get the type ID.
uint32_t GetNBytes(void) const
Get the amount of bytes stored by the queue disc.
TracedCallback< Ptr< const QueueDiscItem >, const char * > m_traceDropBeforeEnqueue
Traced callback: fired when a packet is dropped before enqueue.
void AddQueueDiscClass(Ptr< QueueDiscClass > qdClass)
Add a queue disc class to the tail of the list of classes.
bool m_peeked
A packet was dequeued because Peek was called.
QueueSize m_maxSize
max queue size
virtual void SetQuota(const uint32_t quota)
Set the maximum number of dequeue operations following a packet enqueue.
uint64_t GetNMarkedBytes(std::string reason) const
Get the amount of bytes marked for the given reason.
void DoInitialize(void)
Check whether the configuration is correct and initialize parameters.
std::size_t GetNPacketFilters(void) const
Get the number of packet filters.
void SetQueueDisc(Ptr< QueueDisc > qd)
Set the queue disc attached to this class.
WakeMode
Used to determine whether the queue disc itself or its children must be activated when a netdevice wa...
uint64_t nTotalDroppedBytesBeforeEnqueue
Total bytes dropped before enqueue.
TracedCallback< Ptr< const QueueDiscItem > > m_traceRequeue
Traced callback: fired when a packet is requeued.
bool Mark(Ptr< QueueDiscItem > item, const char *reason)
Marks the given packet and, if successful, updates the counters associated with the given reason.
static constexpr const char * CHILD_QUEUE_DISC_DROP
Packet dropped by a child queue disc.
Ptr< const QueueDiscItem > Peek(void)
Get a copy of the next packet the queue discipline will extract.
std::function< void(Ptr< const QueueDiscItem >, const char *)> ChildQueueDiscMarkFunctor
Type for the function objects notifying that a packet has been marked by a child queue disc.
QueueDiscClass is the base class for classes that are included in a queue disc.
uint64_t nTotalEnqueuedBytes
Total enqueued bytes.
void PacketEnqueued(Ptr< const QueueDiscItem > item)
Perform the actions required when the queue disc is notified of a packet enqueue.
InternalQueueDropFunctor m_internalQueueDadFunctor
Function object called when an internal queue dropped a packet after dequeue.
bool Transmit(Ptr< QueueDiscItem > item)
Modelled after the Linux function sch_direct_xmit (net/sched/sch_generic.c) Sends a packet to the dev...
Ptr< NetDeviceQueueInterface > GetNetDeviceQueueInterface(void) const
uint32_t nTotalDroppedPacketsBeforeEnqueue
Total packets dropped before enqueue.
void Requeue(Ptr< QueueDiscItem > item)
Modelled after the Linux function dev_requeue_skb (net/sched/sch_generic.c) Requeues a packet whose t...
TracedCallback< Ptr< const QueueDiscItem >, const char * > m_traceMark
Traced callback: fired when a packet is marked.
uint32_t nTotalDroppedPacketsAfterDequeue
Total packets dropped after dequeue.
virtual void DoDispose(void)
Dispose of the object.
virtual void DoDispose(void)
Dispose of the object.
uint32_t nTotalMarkedBytes
Total marked bytes.
virtual void InitializeParams(void)=0
Initialize parameters (if any) before the first packet is enqueued.
uint32_t GetNMarkedPackets(std::string reason) const
Get the number of packets marked for the given reason.
bool m_running
The queue disc is performing multiple dequeue operations.
A base class which provides memory management and object aggregation.
std::string m_childQueueDiscDropMsg
Reason why a packet was dropped by a child queue disc.
uint32_t GetNDroppedPackets(std::string reason) const
Get the number of packets dropped for the given reason.
@ SINGLE_INTERNAL_QUEUE
Used by queue discs with single internal queue.
Introspection did not find any typical Config paths.
uint64_t nTotalRequeuedBytes
Total requeued bytes.
uint64_t nTotalSentBytes
Total sent bytes – this value is not kept up to date, call GetStats first.
virtual Ptr< const QueueDiscItem > DoPeek(void)
Return a copy of the next packet the queue disc will extract.
void AddInternalQueue(Ptr< InternalQueue > queue)
Add an internal queue to the tail of the list of queues.
std::size_t GetNInternalQueues(void) const
Get the number of internal queues.
uint64_t nTotalReceivedBytes
Total received bytes.
QueueSize GetCurrentSize(void)
Get the current size of the queue disc in bytes, if operating in bytes mode, or packets,...
std::map< std::string, uint32_t > nMarkedPackets
Marked packets, for each reason.
TracedCallback< Ptr< const QueueDiscItem >, const char * > m_traceDropAfterDequeue
Traced callback: fired when a packet is dropped after dequeue.
std::map< std::string, uint64_t > nDroppedBytesAfterDequeue
Bytes dropped after dequeue, for each reason.
std::function< void(Ptr< const QueueDiscItem >, const char *)> ChildQueueDiscDropFunctor
Type for the function objects notifying that a packet has been dropped by a child queue disc.
QueueDiscSizePolicy m_sizePolicy
The queue disc size policy.
virtual ~QueueDiscClass()
QueueDisc(QueueDiscSizePolicy policy=QueueDiscSizePolicy::SINGLE_INTERNAL_QUEUE)
Constructor.
uint32_t nTotalEnqueuedPackets
Total enqueued packets.
static constexpr const char * INTERNAL_QUEUE_DROP
Packet dropped by an internal queue.
std::map< std::string, uint64_t > nDroppedBytesBeforeEnqueue
Bytes dropped before enqueue, for each reason.
@ SINGLE_CHILD_QUEUE_DISC
Used by queue discs with single child queue disc.
uint32_t nTotalReceivedPackets
Total received packets.
Ptr< QueueDiscItem > Dequeue(void)
Extract from the queue disc the packet that has been dequeued by calling Peek, if any,...
bool RunBegin(void)
Modelled after the Linux function qdisc_run_begin (include/net/sch_generic.h).
SendCallback m_send
Callback used to send a packet to the receiving object.
TracedValue< uint32_t > m_nBytes
Number of bytes in the queue.
uint32_t GetNPackets(void) const
Get the number of packets stored by the queue disc.
ChildQueueDiscMarkFunctor m_childQueueDiscMarkFunctor
Function object called when a child queue disc marked a packet.
uint64_t GetNDroppedBytes(std::string reason) const
Get the amount of bytes dropped for the given reason.
virtual Ptr< QueueDiscItem > DoDequeue(void)=0
This function actually extracts a packet from the queue disc.
void AddPacketFilter(Ptr< PacketFilter > filter)
Add a packet filter to the tail of the list of filters used to classify packets.
void Print(std::ostream &os) const
Print the statistics.
ChildQueueDiscDropFunctor m_childQueueDiscDbeFunctor
Function object called when a child queue disc dropped a packet before enqueue.
TracedCallback< Ptr< const QueueDiscItem > > m_traceDequeue
Traced callback: fired when a packet is dequeued.
void DropAfterDequeue(Ptr< const QueueDiscItem > item, const char *reason)
Perform the actions required when the queue disc is notified of a packet dropped after dequeue.
ChildQueueDiscDropFunctor m_childQueueDiscDadFunctor
Function object called when a child queue disc dropped a packet after dequeue.
bool m_prohibitChangeMode
True if changing mode is prohibited.
uint64_t nTotalDequeuedBytes
Total dequeued bytes.
std::string m_childQueueDiscMarkMsg
Reason why a packet was marked by a child queue disc.
static const uint32_t DEFAULT_QUOTA
Default quota (as in /proc/sys/net/core/dev_weight)
virtual bool DoEnqueue(Ptr< QueueDiscItem > item)=0
This function actually enqueues a packet into the queue disc.
QueueSizeUnit
Enumeration of the operating modes of queues.
uint64_t nTotalDroppedBytes
Total dropped bytes.
Ptr< QueueDiscItem > DequeuePacket(void)
Modelled after the Linux function dequeue_skb (net/sched/sch_generic.c)
uint64_t nTotalDroppedBytesAfterDequeue
Total bytes dropped after dequeue.
virtual WakeMode GetWakeMode(void) const
When setting up the wake callbacks on the netdevice queues, it is necessary to determine which queue ...
Forward calls to a chain of Callback.
TracedCallback< Ptr< const QueueDiscItem > > m_traceDrop
Traced callback: fired when a packet is dropped.
std::function< void(Ptr< QueueDiscItem >)> SendCallback
Callback invoked to send a packet to the receiving object when Run is called.
std::map< std::string, uint64_t > nMarkedBytes
Marked bytes, for each reason.
int32_t Classify(Ptr< QueueDiscItem > item)
Classify a packet by calling the packet filters, one at a time, until either a filter able to classif...
const Stats & GetStats(void)
Retrieve all the collected statistics.
TracedValue< uint32_t > m_nPackets
Number of packets in the queue.
Ptr< NetDeviceQueueInterface > m_devQueueIface
NetDevice queue interface.
std::size_t GetNQueueDiscClasses(void) const
Get the number of queue disc classes.
void DropBeforeEnqueue(Ptr< const QueueDiscItem > item, const char *reason)
Perform the actions required when the queue disc is notified of a packet dropped before enqueue.
Ptr< InternalQueue > GetInternalQueue(std::size_t i) const
Get the i-th internal queue.
std::ostream & operator<<(std::ostream &os, const Angles &a)
void SetSendCallback(SendCallback func)
SendCallback GetSendCallback(void) const
Class for representing queue sizes.
Stats m_stats
The collected statistics.
std::vector< Ptr< QueueDiscClass > > m_classes
Classes.
InternalQueueDropFunctor m_internalQueueDbeFunctor
Function object called when an internal queue dropped a packet before enqueue.
QueueDisc(const QueueDisc &o)
Copy constructor.
void PacketDequeued(Ptr< const QueueDiscItem > item)
Perform the actions required when the queue disc is notified of a packet dequeue.
void SetNetDeviceQueueInterface(Ptr< NetDeviceQueueInterface > ndqi)
Ptr< QueueDiscItem > m_requeued
The last packet that failed to be transmitted.
std::vector< Ptr< InternalQueue > > m_queues
Internal queues.
bool Restart(void)
Modelled after the Linux function qdisc_restart (net/sched/sch_generic.c) Dequeue a packet (by callin...