blob: 573a567ade25a50a5dc8d1edcf8b0b6a76f349ca [file] [log] [blame]
Alexander Afanasyevc74a6022011-08-15 20:01:35 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil -*- */
Alexander Afanasyev08d984e2011-08-13 19:20:22 -07002/*
Alexander Afanasyev7112f482011-08-17 14:05:57 -07003 * Copyright (c) 2011 University of California, Los Angeles
Alexander Afanasyev08d984e2011-08-13 19:20:22 -07004 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation;
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 *
Alexander Afanasyev7112f482011-08-17 14:05:57 -070018 * Author: Alexander Afanasyev <alexander.afanasyev@ucla.edu>
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070019 */
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070020
Alexander Afanasyev7112f482011-08-17 14:05:57 -070021#ifndef _CCNX_H_
22#define _CCNX_H_
23
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070024#include "ns3/object.h"
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070025#include "ns3/callback.h"
Alexander Afanasyevf377b332011-12-16 15:32:12 -080026#include "ns3/traced-callback.h"
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070027
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070028namespace ns3 {
29
30class Node;
31class NetDevice;
32class Packet;
Alexander Afanasyevc74a6022011-08-15 20:01:35 -070033class CcnxForwardingStrategy;
Alexander Afanasyev78cf0c92011-09-01 19:57:14 -070034class CcnxFace;
Alexander Afanasyevcf133f02011-09-06 12:13:48 -070035class CcnxContentObjectHeader;
36class CcnxInterestHeader;
Alexander Afanasyev7f3e49e2012-04-30 00:17:07 -070037class CcnxPit;
Alexander Afanasyev78cf0c92011-09-01 19:57:14 -070038
Alexander Afanasyev6315ef72012-06-01 20:56:31 -070039/// @cond include_hidden
Alexander Afanasyev78cf0c92011-09-01 19:57:14 -070040/**
41 * \internal
42 * \brief Private namespace for CCNx content store implementation
43 */
44namespace __ccnx_private
45{
46class i_face {};
47class i_metric {};
48class i_nth {};
49class i_prefix {};
50class i_ordered {}; ///< tag for Boost.MultiIndex container (ordered by prefix)
51class i_mru {};
52}
Alexander Afanasyev6315ef72012-06-01 20:56:31 -070053/// @endcond
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070054
Ilya Moiseenkobdf78d62011-10-28 13:20:10 -070055// default data size
Alexander Afanasyeva5bbe0e2011-11-22 17:28:39 -080056// #define NDN_DEFAULT_DATA_SIZE 1024
57// #define NDN_INTEREST_RESET_PERIOD (10*MILLI_SECOND)
58
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070059/**
Alexander Afanasyev7112f482011-08-17 14:05:57 -070060 * \defgroup ccnx NDN abstraction
61 *
62 * This is an abstract implementation of NDN protocol
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070063 */
64/**
65 * \ingroup ccnx
Alexander Afanasyev7112f482011-08-17 14:05:57 -070066 * \brief Interface to manage Ccnx stack
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070067 *
68 * This class defines the API to manipulate the following aspects of
Alexander Afanasyev7112f482011-08-17 14:05:57 -070069 * the Ccnx stack implementation:
70 * -# register a face (CcnxFace-derived object) for use by the Ccnx
71 * layer
72 * -# register forwarding strategy (CcnxForwardingStrategy-derived
73 * object) to use by Ccnx stack
74 * -# export Ccnx configuration attributes
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070075 *
Alexander Afanasyev7112f482011-08-17 14:05:57 -070076 * Each CcnxFace-derived object has conceptually a single Ccnx
77 * interface associated with it.
78 *
79 * In addition, this class defines CCNx packet coding constants
80 *
81 * \see CcnxFace, CcnxForwardingStrategy
Alexander Afanasyev08d984e2011-08-13 19:20:22 -070082 */
83class Ccnx : public Object
84{
85public:
Alexander Afanasyev7112f482011-08-17 14:05:57 -070086 /**
87 * \brief Interface ID
88 *
89 * \return interface ID
90 */
91 static TypeId GetTypeId ();
Alexander Afanasyev4fa5e842011-11-21 13:38:39 -080092 virtual ~Ccnx ();
Alexander Afanasyev3a4a0b32012-06-28 14:14:22 -070093
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -070094 /**
95 * \brief Add face to CCNx stack
96 *
97 * \param face smart pointer to CcnxFace-derived object
98 * (CcnxLocalFace, CcnxNetDeviceFace, CcnxUdpFace) \returns the
99 * index of the Ccnx interface added.
100 *
101 * \see CcnxLocalFace, CcnxNetDeviceFace, CcnxUdpFace
102 */
103 virtual uint32_t
104 AddFace (const Ptr<CcnxFace> &face) = 0;
105
106 /**
107 * \brief Get current number of faces added to CCNx stack
108 *
109 * \returns the number of faces
110 */
111 virtual uint32_t
112 GetNFaces (void) const = 0;
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700113
114 /**
Alexander Afanasyevc5a23e22011-09-07 00:37:36 -0700115 * \brief Get face by face index
Alexander Afanasyev98256102011-08-14 01:00:02 -0700116 * \param face The face number of an Ccnx interface.
117 * \returns The CcnxFace associated with the Ccnx face number.
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700118 */
Alexander Afanasyev56f79ea2011-08-17 23:54:27 -0700119 virtual Ptr<CcnxFace>
120 GetFace (uint32_t face) const = 0;
Alexander Afanasyevc5a23e22011-09-07 00:37:36 -0700121
122 /**
123 * \brief Remove face from ccnx stack (remove callbacks)
124 */
125 virtual void
126 RemoveFace (Ptr<CcnxFace> face) = 0;
Alexander Afanasyev52e9aa92011-11-15 20:23:20 -0800127
128 /**
Alexander Afanasyev7f3e49e2012-04-30 00:17:07 -0700129 * \brief Get face for NetDevice
Alexander Afanasyev52e9aa92011-11-15 20:23:20 -0800130 */
131 virtual Ptr<CcnxFace>
132 GetFaceByNetDevice (Ptr<NetDevice> netDevice) const = 0;
Alexander Afanasyevf377b332011-12-16 15:32:12 -0800133
Alexander Afanasyev7f3e49e2012-04-30 00:17:07 -0700134 /**
Alexander Afanasyevf377b332011-12-16 15:32:12 -0800135 * \enum DropReason
136 * \brief A reason why the packet has been dropped
137 */
138 enum DropReason
139 {
140 DUPLICATED, // Interests
141 SUPPRESSED, // Interests and Nacks
142 NO_FACES, // Interests
143 NON_DUPLICATED, // Nacks
144 AFTER_SATISFIED, // Nacks
Alexander Afanasyevf034cbd2012-06-29 14:28:31 -0700145 UNSOLICITED, // data
146 PIT_LIMIT // PIT limit reached
Alexander Afanasyevf377b332011-12-16 15:32:12 -0800147 };
148
149protected:
150 ////////////////////////////////////////////////////////////////////
151 ////////////////////////////////////////////////////////////////////
152 ////////////////////////////////////////////////////////////////////
153
154 // transmittedInterestTrace is inside ForwardingStrategy
155
156 TracedCallback<Ptr<const CcnxInterestHeader>,
Alexander Afanasyevb4fee8b2012-06-06 12:54:26 -0700157 Ptr<const CcnxFace> > m_inInterests; ///< @brief trace of incoming Interests
Alexander Afanasyevf377b332011-12-16 15:32:12 -0800158
159 TracedCallback<Ptr<const CcnxInterestHeader>,
160 DropReason,
Alexander Afanasyevb4fee8b2012-06-06 12:54:26 -0700161 Ptr<const CcnxFace> > m_dropInterests; ///< @brief trace of dropped Interests
Alexander Afanasyevf377b332011-12-16 15:32:12 -0800162
163 ////////////////////////////////////////////////////////////////////
164 ////////////////////////////////////////////////////////////////////
165 ////////////////////////////////////////////////////////////////////
166
167 TracedCallback<Ptr<const CcnxInterestHeader>,
Alexander Afanasyevb4fee8b2012-06-06 12:54:26 -0700168 Ptr<const CcnxFace> > m_outNacks; ///< @brief trace of outgoing NACKs
Alexander Afanasyevf377b332011-12-16 15:32:12 -0800169
170 TracedCallback<Ptr<const CcnxInterestHeader>,
Alexander Afanasyevb4fee8b2012-06-06 12:54:26 -0700171 Ptr<const CcnxFace> > m_inNacks; ///< @brief trace of incoming NACKs
Alexander Afanasyevf377b332011-12-16 15:32:12 -0800172
173 TracedCallback<Ptr<const CcnxInterestHeader>,
174 DropReason,
Alexander Afanasyevb4fee8b2012-06-06 12:54:26 -0700175 Ptr<const CcnxFace> > m_dropNacks; ///< @brief trace of dropped NACKs
Alexander Afanasyevf377b332011-12-16 15:32:12 -0800176
177 ////////////////////////////////////////////////////////////////////
178 ////////////////////////////////////////////////////////////////////
179 ////////////////////////////////////////////////////////////////////
180
Alexander Afanasyevc86c2832011-12-23 02:56:22 -0800181 TracedCallback<Ptr<const CcnxContentObjectHeader>, Ptr<const Packet>,
Alexander Afanasyevf377b332011-12-16 15:32:12 -0800182 bool /*from cache*/,
Alexander Afanasyevb4fee8b2012-06-06 12:54:26 -0700183 Ptr<const CcnxFace> > m_outData; ///< @brief trace of outgoing Data
Alexander Afanasyevf377b332011-12-16 15:32:12 -0800184
Alexander Afanasyevc86c2832011-12-23 02:56:22 -0800185 TracedCallback<Ptr<const CcnxContentObjectHeader>, Ptr<const Packet>,
Alexander Afanasyevb4fee8b2012-06-06 12:54:26 -0700186 Ptr<const CcnxFace> > m_inData; ///< @brief trace of incoming Data
Alexander Afanasyevf377b332011-12-16 15:32:12 -0800187
Alexander Afanasyevc86c2832011-12-23 02:56:22 -0800188 TracedCallback<Ptr<const CcnxContentObjectHeader>, Ptr<const Packet>,
Alexander Afanasyevf377b332011-12-16 15:32:12 -0800189 DropReason,
Alexander Afanasyevb4fee8b2012-06-06 12:54:26 -0700190 Ptr<const CcnxFace> > m_dropData; ///< @brief trace of dropped Data
Alexander Afanasyev08d984e2011-08-13 19:20:22 -0700191};
192
193} // namespace ns3
194
Alexander Afanasyev7112f482011-08-17 14:05:57 -0700195#endif /* _CCNX_H_ */