RINASim  October 2016
Documentation of framework for OMNeT++
QueuePerNQoSxPLen.cc
Go to the documentation of this file.
1 // The MIT License (MIT)
2 //
3 // Copyright (c) 2014-2016 Brno University of Technology, PRISTINE project
4 //
5 // Permission is hereby granted, free of charge, to any person obtaining a copy
6 // of this software and associated documentation files (the "Software"), to deal
7 // in the Software without restriction, including without limitation the rights
8 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 // copies of the Software, and to permit persons to whom the Software is
10 // furnished to do so, subject to the following conditions:
11 //
12 // The above copyright notice and this permission notice shall be included in
13 // all copies or substantial portions of the Software.
14 //
15 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21 // THE SOFTWARE.
22 
23 #include "QueuePerNQoSxPLen.h"
24 
26 
27 using namespace std;
28 
30 
31  rmtAllocator->addQueue(RMTQueue::OUTPUT, port, "M");
32  rmtAllocator->addQueue(RMTQueue::INPUT, port, "M");
33  rmtAllocator->addQueue(RMTQueue::INPUT, port, "Q");
34 
35  // get this IPCP's QoS cubes
36  const QoSCubeSet& cubes = ra->getQoSCubes();
37 
38  for (QCubeCItem it = cubes.begin(); it != cubes.end(); ++it) {
39  if (it->getQosId() == VAL_MGMTQOSID) continue;
40 
41  for(int i = 1; i <= maxHCount; i++) {
42  string q = it->getQosId() + "_" + to_string(i);
43  rmtAllocator->addQueue(RMTQueue::OUTPUT, port, q.c_str());
44  }
45  }
46 }
47 
48 
50  maxHCount = par("maxHCount").longValue();
51  if(maxHCount <= 0) { maxHCount = 1; }
52 }
const std::string VAL_MGMTQOSID
Definition: QoSCube.cc:37
Define_Module(QueuePerNQoSxPLen)
QoSCubeSet::const_iterator QCubeCItem
Definition: RABase.h:34
std::list< QoSCube > QoSCubeSet
Definition: RABase.h:33
virtual void onNM1PortInit(RMTPort *port)