blob: 9e58494f6859ab5508e72243eb02b492b05f12e5 [file] [log] [blame]
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Hila Ben Abraham39a79be2016-03-30 22:00:55 -07003 * Copyright (c) 2014-2016, Regents of the University of California,
Junxiao Shi1e46be32015-01-08 20:18:05 -07004 * 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.
Alexander Afanasyev9bcbc7c2014-04-06 19:37:37 -070010 *
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/>.
Junxiao Shi82e7f582014-09-07 15:15:40 -070024 */
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -070025
Alexander Afanasyev613e2a92014-04-15 13:36:58 -070026#ifndef NFD_DAEMON_FW_NCC_STRATEGY_HPP
27#define NFD_DAEMON_FW_NCC_STRATEGY_HPP
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -070028
29#include "strategy.hpp"
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -070030
31namespace nfd {
32namespace fw {
33
34/** \brief a forwarding strategy similar to CCNx 0.7.2
35 */
36class NccStrategy : public Strategy
37{
38public:
Junxiao Shif3c07812014-03-11 21:48:49 -070039 NccStrategy(Forwarder& forwarder, const Name& name = STRATEGY_NAME);
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -070040
41 virtual
42 ~NccStrategy();
43
44 virtual void
45 afterReceiveInterest(const Face& inFace,
46 const Interest& interest,
47 shared_ptr<fib::Entry> fibEntry,
Davide Pesaventob84bd3a2016-04-22 02:21:45 +020048 shared_ptr<pit::Entry> pitEntry) override;
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -070049
50 virtual void
Junxiao Shi82e7f582014-09-07 15:15:40 -070051 beforeSatisfyInterest(shared_ptr<pit::Entry> pitEntry,
Davide Pesaventob84bd3a2016-04-22 02:21:45 +020052 const Face& inFace, const Data& data) override;
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -070053
Hila Ben Abraham39a79be2016-03-30 22:00:55 -070054PUBLIC_WITH_TESTS_ELSE_PROTECTED:
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -070055 /// StrategyInfo on measurements::Entry
56 class MeasurementsEntryInfo : public StrategyInfo
57 {
58 public:
Junxiao Shi39ef2612014-11-29 20:35:19 -070059 static constexpr int
60 getTypeId()
61 {
62 return 1000;
63 }
64
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -070065 MeasurementsEntryInfo();
66
67 void
68 inheritFrom(const MeasurementsEntryInfo& other);
69
70 shared_ptr<Face>
71 getBestFace();
72
73 void
74 updateBestFace(const Face& face);
75
76 void
77 adjustPredictUp();
78
79 private:
80 void
81 adjustPredictDown();
82
83 void
84 ageBestFace();
85
86 public:
Junxiao Shi1391d612014-03-27 22:27:20 -070087 weak_ptr<Face> bestFace;
88 weak_ptr<Face> previousFace;
89 time::microseconds prediction;
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -070090
Junxiao Shi1391d612014-03-27 22:27:20 -070091 static const time::microseconds INITIAL_PREDICTION;
92 static const time::microseconds MIN_PREDICTION;
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -070093 static const int ADJUST_PREDICT_DOWN_SHIFT = 7;
Junxiao Shi1391d612014-03-27 22:27:20 -070094 static const time::microseconds MAX_PREDICTION;
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -070095 static const int ADJUST_PREDICT_UP_SHIFT = 3;
96 };
97
98 /// StrategyInfo on pit::Entry
99 class PitEntryInfo : public StrategyInfo
100 {
101 public:
Junxiao Shi39ef2612014-11-29 20:35:19 -0700102 static constexpr int
103 getTypeId()
104 {
105 return 1001;
106 }
107
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -0700108 virtual
109 ~PitEntryInfo();
110
111 public:
Junxiao Shicbb490a2014-08-13 12:24:24 -0700112 /// timer that expires when best face does not respond within predicted time
Junxiao Shi1e46be32015-01-08 20:18:05 -0700113 scheduler::EventId bestFaceTimeout;
Junxiao Shicbb490a2014-08-13 12:24:24 -0700114 /// timer for propagating to another face
Junxiao Shi1e46be32015-01-08 20:18:05 -0700115 scheduler::EventId propagateTimer;
Junxiao Shicbb490a2014-08-13 12:24:24 -0700116 /// maximum interval between forwarding to two nexthops except best and previous
Junxiao Shi1391d612014-03-27 22:27:20 -0700117 time::microseconds maxInterval;
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -0700118 };
119
120protected:
121 shared_ptr<MeasurementsEntryInfo>
122 getMeasurementsEntryInfo(shared_ptr<measurements::Entry> entry);
123
124 shared_ptr<MeasurementsEntryInfo>
125 getMeasurementsEntryInfo(shared_ptr<pit::Entry> entry);
126
127 /// propagate to another upstream
128 void
129 doPropagate(weak_ptr<pit::Entry> pitEntryWeak, weak_ptr<fib::Entry> fibEntryWeak);
130
131 /// best face did not reply within prediction
132 void
133 timeoutOnBestFace(weak_ptr<pit::Entry> pitEntryWeak);
134
Junxiao Shif3c07812014-03-11 21:48:49 -0700135public:
136 static const Name STRATEGY_NAME;
137
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -0700138protected:
Junxiao Shi1391d612014-03-27 22:27:20 -0700139 static const time::microseconds DEFER_FIRST_WITHOUT_BEST_FACE;
140 static const time::microseconds DEFER_RANGE_WITHOUT_BEST_FACE;
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -0700141 static const int UPDATE_MEASUREMENTS_N_LEVELS = 2;
Alexander Afanasyeveb3197f2014-03-17 19:28:18 -0700142 static const time::nanoseconds MEASUREMENTS_LIFETIME;
Junxiao Shi0b5fbbb2014-02-20 15:54:03 -0700143};
144
145} // namespace fw
146} // namespace nfd
147
Alexander Afanasyev613e2a92014-04-15 13:36:58 -0700148#endif // NFD_DAEMON_FW_NCC_STRATEGY_HPP