process-nack-traits.cpp
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2014-2022, 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 #include "process-nack-traits.hpp"
27 #include "common/logger.hpp"
28 
29 namespace nfd::fw {
30 
31 NFD_LOG_INIT(ProcessNackTraits);
32 
33 void
34 ProcessNackTraitsBase::processNack(const lp::Nack& nack, const Face& inFace,
35  const shared_ptr<pit::Entry>& pitEntry)
36 {
37  int nOutRecordsNotNacked = 0;
38  Face* lastFaceNotNacked = nullptr;
39  lp::NackReason leastSevereReason = lp::NackReason::NONE;
40  for (const pit::OutRecord& outR : pitEntry->getOutRecords()) {
41  const lp::NackHeader* inNack = outR.getIncomingNack();
42  if (inNack == nullptr) {
43  ++nOutRecordsNotNacked;
44  lastFaceNotNacked = &outR.getFace();
45  continue;
46  }
47 
48  if (isLessSevere(inNack->getReason(), leastSevereReason)) {
49  leastSevereReason = inNack->getReason();
50  }
51  }
52 
53  lp::NackHeader outNack;
54  outNack.setReason(leastSevereReason);
55 
56  if (nOutRecordsNotNacked == 1) {
57  BOOST_ASSERT(lastFaceNotNacked != nullptr);
58  auto inR = pitEntry->getInRecord(*lastFaceNotNacked);
59  if (inR != pitEntry->in_end()) {
60  // one out-record not Nacked, which is also a downstream
61  NFD_LOG_DEBUG(nack.getInterest() << " nack-from=" << inFace.getId() <<
62  " nack=" << nack.getReason() <<
63  " nack-to(bidirectional)=" << lastFaceNotNacked->getId() <<
64  " out-nack=" << outNack.getReason());
65  this->sendNackForProcessNackTraits(pitEntry, *lastFaceNotNacked, outNack);
66  return;
67  }
68  }
69 
70  if (nOutRecordsNotNacked > 0) {
71  NFD_LOG_DEBUG(nack.getInterest() << " nack-from=" << inFace.getId() <<
72  " nack=" << nack.getReason() <<
73  " waiting=" << nOutRecordsNotNacked);
74  // continue waiting
75  return;
76  }
77 
78  NFD_LOG_DEBUG(nack.getInterest() << " nack-from=" << inFace.getId() <<
79  " nack=" << nack.getReason() <<
80  " nack-to=all out-nack=" << outNack.getReason());
81  this->sendNacksForProcessNackTraits(pitEntry, outNack);
82 }
83 
84 } // namespace nfd::fw
Generalization of a network interface.
Definition: face.hpp:56
FaceId getId() const noexcept
Returns the face ID.
Definition: face.hpp:121
void processNack(const lp::Nack &nack, const Face &inFace, const shared_ptr< pit::Entry > &pitEntry)
Contains information about an Interest toward an outgoing face.
#define NFD_LOG_INIT(name)
Definition: logger.hpp:31
#define NFD_LOG_DEBUG
Definition: logger.hpp:38