EMANE  1.2.1
rfpipe/downstreamqueue.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2013-2015 - Adjacent Link LLC, Bridgewater, New Jersey
3  * Copyright (c) 2010 - DRS CenGen, LLC, Columbia, Maryland
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  *
10  * * Redistributions of source code must retain the above copyright
11  * notice, this list of conditions and the following disclaimer.
12  * * Redistributions in binary form must reproduce the above copyright
13  * notice, this list of conditions and the following disclaimer in
14  * the documentation and/or other materials provided with the
15  * distribution.
16  * * Neither the name of DRS CenGen, LLC nor the names of its
17  * contributors may be used to endorse or promote products derived
18  * from this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
24  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
26  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
27  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
28  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
30  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31  * POSSIBILITY OF SUCH DAMAGE.
32  */
33 
34 #ifndef RFPIPEMAC_DOWNSTREAMQUEUE_HEADER_
35 #define RFPIPEMAC_DOWNSTREAMQUEUE_HEADER_
36 
37 #include "emane/types.h"
38 #include "emane/phylayerimpl.h"
40 #include "emane/statisticnumeric.h"
41 
42 #include <queue>
43 #include <vector>
44 
45 namespace EMANE
46 {
47  namespace Models
48  {
49  namespace RFPipe
50  {
57  {
58  DownstreamPacket pkt_; // packet payload
59  TimePoint acquireTime_; // packet acquire time (absolute time)
60  Microseconds durationMicroseconds_; // packet transmission duration
61  std::uint64_t u64DataRatebps_; // packet data rate bps
62 
64  pkt_{DownstreamPacket{EMANE::PacketInfo{0,0,0,{}},nullptr,0}},
65  acquireTime_{},
66  durationMicroseconds_{},
67  u64DataRatebps_{}
68  {}
69 
70 
82  const TimePoint & acquireTime,
83  const Microseconds & durationMicroseconds,
84  std::uint64_t u64DataRatebps) :
85  pkt_{std::move(pkt)},
86  acquireTime_{acquireTime},
87  durationMicroseconds_{durationMicroseconds},
88  u64DataRatebps_{u64DataRatebps}
89  {}
90  };
91 
92 
93  typedef std::queue<DownstreamQueueEntry> DownstreamPacketQueue;
94 
102  {
103  public:
104 
109  DownstreamQueue();
110 
116  ~DownstreamQueue();
117 
118  void registerStatistics(StatisticRegistrar & statisticRegistrar);
119 
128  size_t getNumDiscards(bool bClear);
129 
130 
138  size_t getCurrentDepth();
139 
147  size_t getMaxCapacity();
148 
156  std::pair<DownstreamQueueEntry,bool> dequeue();
157 
167  std::vector<DownstreamQueueEntry>
168  enqueue(DownstreamQueueEntry &entry);
169 
177  const DownstreamQueueEntry & peek();
178 
179 
180  private:
181  DownstreamPacketQueue queue_;
182  const size_t maxQueueSize_;
183  size_t numDiscards_;
184  StatisticNumeric<std::uint32_t> * pNumHighWaterMark_;
185  };
186  }
187  }
188 }
189 
190 #endif //RFPIPEMAC_DOWNSTREAMQUEUE_HEADER_
Provides a queue implementation for the RFPipe Mac layer.
DownstreamQueueEntry(DownstreamPacket &pkt, const TimePoint &acquireTime, const Microseconds &durationMicroseconds, std::uint64_t u64DataRatebps)
initializer
RFPipe MAC downstream queue entry definition.
Store source, destination, creation time and priority information for a packet.
Definition: packetinfo.h:50
The StatisticRegistrar allows NEM layers to register statistics and statistic tables. Statistics and Statistic tables are owned by the emulator framework and a borrowed reference is returned to the registering NEM layer.
std::queue< DownstreamQueueEntry > DownstreamPacketQueue
Specialized packet the allows downstream processing to add layer specific headers as the packet trave...
std::chrono::microseconds Microseconds
Definition: types.h:45
Clock::time_point TimePoint
Definition: types.h:50
Definition: agent.h:43