blob: d9197d4d4b2d1de37488910c0197bed44817fce8 [file] [log] [blame]
Nick Gordonf3a9ecb2017-01-24 13:55:14 -06001\section{Name Prefix Table}
2\label{sec:npt}
3
4\begin{figure}[!h]
5 \center
6 \includegraphics[width=0.8\linewidth]{npt}
7 \begin{caption}
8 A diagram of the NPT and Routing Table.
9
10 \begin{footnotesize}
11 The ``wire'' arrows represent references (i.e. ``x has y''),
Nick Gordoneafb2a22017-01-24 14:55:56 -060012 whereas the ``solid'' arrows represent inheritance (i.e. ``y subclasses x''). \\
13 The quantification (e.g. 0..*) is standard UML.
Nick Gordonf3a9ecb2017-01-24 13:55:14 -060014 \end{footnotesize}
15 \end{caption}
16 \label{fig:npt-class-diagram}
17\end{figure}
18
19The Name Prefix Table (NPT) is used by NLSR to maintain a list of all known name prefixes advertised by other routers, including router names.
20The NPT maintains a collection of NPT entries, where each entry represents a name prefix and all of its associated routing table entries.
21Additionally, to optimize the storage and association of the routing table entries, the NPT also maintains a collection of duplicated routing table entries, called routing table pool entries, which have an additional use count attribute.
22The NPT entries keep shared pointers to the appropriate routing table pool entries.
23If a name prefix is advertised by multiple routers, the name prefix will be represented by only one Name Prefix Table Entry, but will have multiple routing table pool entries which correspond with each origin router.
24
25If a Name LSA exists with an advertised name prefix, that advertised name prefix must be represented in the NPT.
26Thus, if two routers advertise the same name prefix and one Name LSA expires, the NPT entry must not be removed due to the existence of the Name LSA from the other router.
27
28If an any type of LSA for a remote router exists in the LSDB, the remote router's name prefix must be present in the NPT.
29An NPT Entry for a router name can be safely removed when there are no more LSAs in the LSDB from the origin router or there are no routing table entries for the origin router.
30
31\subsection{Adding an NPT Entry}
32\label{sec:npt-add}
33The \texttt{NamePrefixTable::addEntry()} method is the public interface for name prefixes to be added to the NPT.
34The name prefix as well as the router's prefix which originates the name prefix are passed as parameters to the interface.
35The NPT will look through its collection of routing table pool entries first to see if it already has the appropriate route.
36If the NPT locates a local entry, it will increment that entry's use count.
37If none can be found, if will check in the Routing Table to see if a ``raw'' routing table entry matching the origin of the prefix is available there.
38If one is found, it will create a routing table pool entry with the same information, and a use count of one. This new routing table pool entry will then be used.
39If one is not found, a routing table pool entry with no routing information and a use count of one is made, and the NPT entry will retain this ``dummy'' routing information until the Routing Table performs a calculation and updates it.
40
41The rest of the method determines if this NPT entry already exists in the NPT itself.
42If it has not been added, i.e. it is new, a new NPT entry will be made and installed in the NPT.
43Then the routing table pool entry with the routing information to the origin router's prefix will be added to this new NPT entry.
44If the entry already exists in the NPT, then the existing entry will be updated in the same way as the new one.
45If the updated NPT entry has next hops, the NPT will update the FIB with the prefix and its next hops.
46If there are no next hops, then this means that there is no way for the router to reach the origin.
47The FIB entry will be removed, but the NPT entry will be retained, as the routing table may calculate a new route.
48
49\subsection{Removing an NPT Entry}
50\label{sec:npt-del}
51The \texttt{NamePrefixTable::removeEntry()} method is the public interface for name prefixes to be removed from the NPT.
52The name prefix as well as the router's prefix which originates the name prefix are passed as parameters to the interface.
53The NPT will use the origin router's name to look through its local collection of routing table pool entries.
54Because this is the NPT's centralized, total pool of routing information, if the entry does not exist here it cannot exist in any NPT entries.
55In that case, the method ends.
56Else, the method will look through the collection of NPT entries for the entry matching the name prefix in the parameters.
57If it does not find it, there is nothing to be done, and the method ends.
58If it does find a matching entry, it will remove from that entry the routing table pool entry with the origin router prefix matching the one given in the parameters.
59The next hop information of the entry is rebuilt, and then the method checks if the entry has any next hops.
60If it does, the method will inform the FIB of the change with the name prefix and the next hops.
61If the entry no longer has any next hops, this means that there is no routing information to any router advertising that prefix.
62In this case, the NPT will remove that entry, as it is no longer useful.
63
64\subsection{Updating an NPT Entry with New Routing Table Entries}
65\label{sec:npt-update-with-new-route}
66When the Routing Table module has finished calculating, it will notify the NPT using the \texttt{NamePrefixTable::updateWithNewRoute()} interface.
67The NPT will then iterate over each of its entries and each entry's routing table pool entry list.
68For each routing entry in the list, the NPT will attempt to fetch the new next hop list from the Routing Table, and set the entry's next hop list to that.
69If no list is available, it clears the routing table pool entry's next hop list.
70Then, \texttt{NamePrefixTable::addEntry()} is called with the current NPT entry and routing table pool entry pair.
71
72\subsection{Adding routing table pool entries to the pool}
73\label{sec:npt-rtpe-add}
74Whenever a routing table pool entry (RTPE) needs to be constructed, the method \texttt{NamePrefixTable::addRtpeToPool()} is called.
75It constructs and inserts into the hash map a pair object whose first element is the origin router prefix, and whose second element is a shared pointer to the actual routing table pool entry object.
76As stated in the \texttt{NamePrefixTable::addEntry()} method, the RTPE will have a use count of one.
77
78\subsection{Removing routing table pool entries from the pool}
79\label{sec:npt-rtpe-del}
Nick Gordoneafb2a22017-01-24 14:55:56 -060080After an RTPE is removed from an NPT entry, it will be deleted from the pool if \texttt{NamePrefixTable::removeEntry()} determines that the RTPE now has a use count of 0.
Nick Gordonf3a9ecb2017-01-24 13:55:14 -060081It will then call \texttt{NamePrefixTable::deleteRtpeFromPool()}, passing the RTPE as a parameter.
82The method will erase the element from the hash map that they are contained in.