NS-3 based Named Data Networking (NDN) simulator
ndnSIM 2.5: NDN, CCN, CCNx, content centric networks
API Documentation
cs-policy-priority-fifo.hpp
Go to the documentation of this file.
1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2
/*
3
* Copyright (c) 2014-2018, Regents of the University of California,
4
* Arizona Board of Regents,
5
* Colorado State University,
6
* University Pierre & Marie Curie, Sorbonne University,
7
* Washington University in St. Louis,
8
* Beijing Institute of Technology,
9
* The University of Memphis.
10
*
11
* This file is part of NFD (Named Data Networking Forwarding Daemon).
12
* See AUTHORS.md for complete list of NFD authors and contributors.
13
*
14
* NFD is free software: you can redistribute it and/or modify it under the terms
15
* of the GNU General Public License as published by the Free Software Foundation,
16
* either version 3 of the License, or (at your option) any later version.
17
*
18
* NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
19
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
20
* PURPOSE. See the GNU General Public License for more details.
21
*
22
* You should have received a copy of the GNU General Public License along with
23
* NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
24
*/
25
26
#ifndef NFD_DAEMON_TABLE_CS_POLICY_PRIORITY_FIFO_HPP
27
#define NFD_DAEMON_TABLE_CS_POLICY_PRIORITY_FIFO_HPP
28
29
#include "
cs-policy.hpp
"
30
#include "
core/scheduler.hpp
"
31
32
#include <list>
33
34
namespace
nfd
{
35
namespace
cs {
36
namespace
priority_fifo {
37
38
typedef
std::list<iterator>
Queue
;
39
typedef
Queue::iterator
QueueIt
;
40
41
enum
QueueType
{
42
QUEUE_UNSOLICITED
,
43
QUEUE_STALE
,
44
QUEUE_FIFO
,
45
QUEUE_MAX
46
};
47
48
struct
EntryInfo
49
{
50
QueueType
queueType
;
51
QueueIt
queueIt
;
52
scheduler::EventId
moveStaleEventId
;
53
};
54
55
struct
EntryItComparator
56
{
57
bool
58
operator()
(
const
iterator
& a,
const
iterator
& b)
const
59
{
60
return
*a < *b;
61
}
62
};
63
64
typedef
std::map<iterator, EntryInfo*, EntryItComparator>
EntryInfoMapFifo
;
65
78
class
PriorityFifoPolicy
:
public
Policy
79
{
80
public
:
81
PriorityFifoPolicy
();
82
83
virtual
84
~PriorityFifoPolicy
();
85
86
public
:
87
static
const
std::string
POLICY_NAME
;
88
89
private
:
90
void
91
doAfterInsert(
iterator
i)
override
;
92
93
void
94
doAfterRefresh(
iterator
i)
override
;
95
96
void
97
doBeforeErase(
iterator
i)
override
;
98
99
void
100
doBeforeUse(
iterator
i)
override
;
101
102
void
103
evictEntries()
override
;
104
105
private
:
109
void
110
evictOne();
111
115
void
116
attachQueue(
iterator
i);
117
121
void
122
detachQueue(
iterator
i);
123
126
void
127
moveToStaleQueue(
iterator
i);
128
129
private
:
130
Queue
m_queues[
QUEUE_MAX
];
131
EntryInfoMapFifo
m_entryInfoMap;
132
};
133
134
}
// namespace priority_fifo
135
136
using
priority_fifo::PriorityFifoPolicy
;
137
138
}
// namespace cs
139
}
// namespace nfd
140
141
#endif // NFD_DAEMON_TABLE_CS_POLICY_PRIORITY_FIFO_HPP
nfd::cs::priority_fifo::EntryInfo::queueIt
QueueIt queueIt
Definition:
cs-policy-priority-fifo.hpp:51
nfd::cs::priority_fifo::PriorityFifoPolicy::~PriorityFifoPolicy
virtual ~PriorityFifoPolicy()
Definition:
cs-policy-priority-fifo.cpp:41
nfd::cs::priority_fifo::QueueType
QueueType
Definition:
cs-policy-priority-fifo.hpp:41
nfd::cs::priority_fifo::QUEUE_FIFO
Definition:
cs-policy-priority-fifo.hpp:44
nfd::cs::priority_fifo::QUEUE_STALE
Definition:
cs-policy-priority-fifo.hpp:43
nfd::cs::iterator
Table::const_iterator iterator
Definition:
cs-internal.hpp:41
nfd::cs::Policy
represents a CS replacement policy
Definition:
cs-policy.hpp:39
nfd::cs::priority_fifo::QUEUE_UNSOLICITED
Definition:
cs-policy-priority-fifo.hpp:42
nfd::cs::priority_fifo::Queue
std::list< iterator > Queue
Definition:
cs-policy-priority-fifo.hpp:38
nfd
Copyright (c) 2011-2015 Regents of the University of California.
Definition:
ndn-common.hpp:40
nfd::cs::priority_fifo::PriorityFifoPolicy::PriorityFifoPolicy
PriorityFifoPolicy()
Definition:
cs-policy-priority-fifo.cpp:36
nfd::cs::priority_fifo::PriorityFifoPolicy::POLICY_NAME
static const std::string POLICY_NAME
Definition:
cs-policy-priority-fifo.hpp:87
nfd::cs::priority_fifo::EntryItComparator
Definition:
cs-policy-priority-fifo.hpp:55
nfd::cs::priority_fifo::EntryInfo::queueType
QueueType queueType
Definition:
cs-policy-priority-fifo.hpp:50
scheduler.hpp
nfd::cs::priority_fifo::EntryInfo::moveStaleEventId
scheduler::EventId moveStaleEventId
Definition:
cs-policy-priority-fifo.hpp:52
cs-policy.hpp
nfd::cs::priority_fifo::QUEUE_MAX
Definition:
cs-policy-priority-fifo.hpp:45
nfd::cs::priority_fifo::EntryInfoMapFifo
std::map< iterator, EntryInfo *, EntryItComparator > EntryInfoMapFifo
Definition:
cs-policy-priority-fifo.hpp:64
ndn::util::scheduler::EventId
A handle of scheduled event.
Definition:
scheduler.hpp:55
nfd::cs::priority_fifo::EntryItComparator::operator()
bool operator()(const iterator &a, const iterator &b) const
Definition:
cs-policy-priority-fifo.hpp:58
nfd::cs::priority_fifo::QueueIt
Queue::iterator QueueIt
Definition:
cs-policy-priority-fifo.hpp:39
nfd::cs::priority_fifo::PriorityFifoPolicy
Priority FIFO replacement policy.
Definition:
cs-policy-priority-fifo.hpp:78
nfd::cs::priority_fifo::EntryInfo
Definition:
cs-policy-priority-fifo.hpp:48
ndnSIM
NFD
daemon
table
cs-policy-priority-fifo.hpp
Generated on Sun Feb 24 2019 22:16:07 for ndnSIM by
1.8.15