Compaq TCP/IP Services for OpenVMS
Management
A.15.2 The Router Discovery Client
A host listens for Router Advertisements via the all-hosts multicast 
address (224.0.0.2), If IP multicasting is available and enabled, or on 
the interface's broadcast address. When starting up, or when 
reconfigured, a host may send a few Router Solicitations to the 
all-routers multicast address, 224.0.0.2, or the interface's broadcast 
address.
When a Router Advertisement with non-zero lifetime is received, the 
host installs a default route to each of the advertised addresses. If 
the preference
ineligible
, or the address is not on an attached interface, the route is marked 
unusable but retained. If the preference is usable, the metric is set 
as a function of the preference such that the route with the best 
preference is used. If more than one address with the same preference 
is received, the one with the lowest IP address will be used. These 
default routes are not exportable to other protocols.
When a Router Advertisement with a zero lifetime is received, the host 
deletes all routes with next-hop addresses learned from that router. In 
addition, any routers learned from ICMP redirects pointing to these 
addresses will be deleted. The same will happen when a Router 
Advertisement is not received to refresh these routes before the 
lifetime expires.
The Router Discovery Client syntax is as follows:
  
    | 
 
 
routerdiscovery client yes | no | on | off [ { 
    traceoptions trace_options ; 
    preference preference ; 
    interface interface_list
        [ enable ] | [ disable ] 
        [ broadcast ] | [ multicast ] 
        [ quiet ] | [ solicit ] 
        ; 
} ] ; 
 | 
In the Router Discovery Client statement:
  - 
traceoptions
specifies the tracing options for OSPF (see Section A.15.3).
  
- 
preference
specifies the preference of all Router Discovery default routes. The 
default is 55.
  
- 
interface
specifies the parameters that apply to physical interfaces. Note a 
slight difference in convention from the rest of GATED,
interface
 specifies just physical interfaces (such as LE0, EF0 and EN1). The 
 Router Discovery Client has no parameters that apply only to interface 
 addresses. 
 The
interface
 parameters that apply to physical interfaces are:
    - 
enable
, which specifies that Router Discovery should be performed on the 
specified interfaces. This is the default.
    
- 
disable
, which specifies that Router Discovery should not be performed on the 
specified interfaces.
    
- 
broadcast
, which specifies that Router Solicitations should be broadcast on the 
specified interfaces. This is the default if IP multicast support is 
not available on this host or interface.
    
- 
multicast
, which specifies that Router Solicitations should be multicast on the 
specified interfaces. If IP multicast is not available on this host and 
interface, no solicitation will be performed. The default is to 
multicast Router Solicitations if the host and interface support it, 
otherwise Router Solicitations are broadcast.
    
- 
quiet
, which specifies that no Router Solicitations will be sent on this 
interface, even though Router Discovery will be performed.
    
- 
solicit
, which specifies that initial Router Solicitations will be sent on 
this interface. This is the default.
  
 
A.15.3 Tracing Options
The Router Discovery Client and Server support the
state
 trace flag, which traces various protocol occurrences.
The Router Discovery Client and Server do not directly support any 
packet tracing options, tracing of router discovery packets is enabled 
with the ICMP statement.
A.16 The Kernel Statement
While the kernel interface is not technically a routing protocol, it 
has many of the characteristics of one, and GATED handles it similarly 
to one. The routes GATED chooses to install in the kernel forwarding 
table are those that will actually be used by the kernel to forward 
packets.
The add, delete and change operations GATED must use to update the 
typical kernel forwarding table take a non-trivial amount of time. This 
does not present a problem for older routing protocols (RIP, EGP), 
which are not particularly time critical and do not easily handle very 
large numbers of routes anyway. The newer routing protocols (OSPF, BGP) 
have stricter timing requirements and are often used to process many 
more routes. The speed of the kernel interface becomes critical when 
these protocols are used.
To prevent GATED from locking up for significant periods of time 
installing large numbers of routes (up to a minute or more has been 
observed on real networks), the processing of these routes is now done 
in batches. The size of these batches may be controlled by the tuning 
parameters described below, but normally the default parameters will 
provide the proper functionality.
During normal shutdown processing, GATED normally deletes all the 
routes it has installed in the kernel forwarding table, except for 
those marked with retain. Optionally, GATED can leave 
all routes in the kernel forwarding table by not deleting any routes. 
In this case changes will be made to insure that routes with a 
retain indication are installed in the table. This is 
useful on systems with large numbers of routes as it prevents the need 
to re-install the routes when GATED restarts. This can greatly reduce 
the time it takes to recover from a restart.
A.16.1 Forwarding Tables and Routing Tables
The table in the kernel that controls the forwarding of packets is a 
forwarding table, also known as a forwarding 
information base, or FIB. The table that GATED uses internally 
to store routing information it learns from routing protocols is a 
routing table, also known as a routing 
information base, or RIB. The routing table is used to collect 
and store routes from various protocols. For each unique combination of 
network and mask an active route is chosen, this route will be the one 
with the best (numerically smallest) preference. All the active routes 
are installed in the kernel forwarding table. The entries in this table 
are what the kernel actually uses to forward packets.
A.16.2 Updating the Forwarding Table
There are two main methods of updating the kernel FIB, the
ioctl()
interface and the routing socket interface. Their various 
characteristics are described here.
A.16.2.1 Updating the Forwarding Table with the ioctl Interface
The
ioctl
 interface to the forwarding table was introduced in BSD 4.3. This is a 
 one-way interface; it only allows GATED to update the kernel forwarding 
 table. It has several other limitations:
  -  Fixed subnet masks 
 The BSD 4.3 networking code assumed that 
  all subnets of a given network had the same subnet mask. This 
  limitation is enforced by the kernel. The network mask is not stored in 
  the kernel forwarding table, but determined when a packet is forwarded 
  by searching for interfaces on the same network.
- One way interface 
 GATED is able to update the kernel forwarding 
  table, but it is not aware of other modifications of the forwarding 
  table. GATED is able to listen to ICMP messages and guess how the 
  kernel has updated the forwarding table with response to ICMP redirects.
- Blind updates 
 GATED is not able to detect changes to the 
  forwarding table resulting from the use of the ROUTE command. Use of 
  the ROUTE command on systems that use the
ioctl()
 interface is strongly discouraged while GATED is running.
- Changes not supported 
 In all known implementations, there is no 
  change operation supported, to change a route that exists in the 
  kernel, the route must be deleted and a new one added.
A.16.2.2 Updating the Forwarding Table with the Routing Socket Interface
The routing socket interface to the kernel forwarding table was 
introduced in BSD 4.3 Reno, widely distributed in BSD 4.3 Net/2 and 
improved in BSD 4.4. This interface is simply a socket, similar to a 
UDP socket, on which the kernel and GATED exchange messages. It has 
several advatages over the
ioctl()
 interface:
  - Variable subnet masks 
 The network mask is passed to the kernel 
  explicitly. This allows different masks to be used on subnets of the 
  same network. It also allows routes with masks that are more general 
  than the natural mask to be used. This is known as classless routing.
- Two way interface 
 Not only is GATED able to change the kernel 
  forwarding table with this interface, but the kernel can also report 
  changes to the forwarding table to GATED. The most interesting of these 
  is an indication that a redirect has modified the kernel forwarding 
  table; this means that GATED no longer needs to monitor ICMP messages 
  to learn about redirects. Plus, there is an indication of whether the 
  kernel processed the redirect, GATED can safely ignore redirect 
  messages that the kernel did not process.
- Updates visible 
 Changes to the routing table by other 
  processes, including the route command are received via the routing 
  socket. This allows GATED to insure that the kernel forwarding table is 
  synchronized with the routing table. Also, it allows the system 
  administrator to perform some operations with the ROUTE command while 
  GATED is running.
- Changes supported 
 There is a functioning change message that 
  allows routes in the kernel to be atomically changed. Some early 
  verions of the routing socket code had bugs in the change message 
  processing. There are compilation time and configuration time options 
  that cause delete and add sequences to be used instead of change 
  messages.
- Expandable 
 New levels of kernel and GATED communications may be 
  added by adding new message types.
A.16.3 Reading the Forwarding Table
When GATED starts up it reads the kernel forwarding table and installs 
corresponding routes in the routing table. These routes are called 
remnants and are timed out after a configured interval (which defaults 
to 3 minutes), or as soon as a more attractive route is learned. This 
allows forwarding to occur during the time it takes the routing 
protocols to start learning routes.
There are three main methods for reading the forwarding table from the 
kernel:
  - Reading forwarding table with KMEM 
 On many systems, especially 
  those based on BSD 4.3, GATED must have knowledge of the kernel's data 
  structures to read the current state of forwarding table. This method 
  is slow and subject to error if the kernel forwarding table is updated 
  while GATED is reading it. This can happen if the system administrator 
  uses the ROUTE command, or an ICMP redirect message is received while 
  GATED is starting up.
 Due to an oversight, some systems (such as 
  OSF/1) that are based on BSD 4.3 Reno or later, do not have the 
  getkerninfo() system call described below, which allows GATED to read 
  routes from the kernel without knowing about kernel internal 
  structures. On these systems it is necessary to read the kernel radix 
  tree from kernel memory. This is even more error-prone than reading the 
  hash based forwding table.
- Reading the forwarding table via
getkerninfo
 or
sysctl
    
 Besides the routing socket, BSD 4.3 Reno introduced the
getkerninfo()
system call. This call allows a user process (of which GATED is one) to 
read information from the kernel without knowledge of the kernel data 
structures. In the case of the forwarding table, it is returned to 
GATED atomically as a series of routing socket messages. This prevents 
the problem associated with the forwarding table changing while GATED 
is in the process of reading it.
 BSD 4.4 changed the
getkerninfo()
 interface into the
sysctl()
interface, which takes different parameters, but otherwise functions 
identically.
- Reading the forwarding table via OS specific methods 
 Some 
  operating systems define their own method of reading the kernel 
  forwarding table.
A.16.4 Reading the Interface List
The kernel support subsystem of GATED is resposible for reading the 
status of the kernel's physical and protocl interfaces periodically. 
GATED detects changes in the interface list and notifies the protocols 
so they can start or stop instances or peers. The interface list is 
read one of two ways:
  - Reading the interface list with SIOCGIFCONF 
 On systems based on 
  BSD 4.3, 4.3 Reno and 4.3 Net/2 the SIOCGIFCONF
ioctl
 interface is used to read the kernel interface list. Using this method, 
 a list of interfaces and some basic information about them is return by 
 the SIOCGIFCONF call. Other information must be learned by issuing other
ioctl
s to learn the interface network mask, flags, MTU, metric, destination 
address (for point-to-point interfaces) and broadcast address (for 
broadcast capable interfaces).
 GATED reads rereads this list every 
15 second looking for changes. When the routing socket is in use, it 
also rereads it whenever a messages is received indicating a change in 
routing configuration. Receipt of a SIGUSR2 signal also causes GATED to 
reread the list. This interval may be explicitly configured in the 
interface configuration.
- Reading the interface list with
sysctl
    
 BSD 4.4 added the ability to read the kernel interface list via the
sysctl
 system call. The interface status is returned atomically as a list of 
 routing socket messages that GATED parses for the required information.
 BSD 4.4 also added routing socket messsages to report interface 
 status changes immediately. This allows GATED to react quickly to 
 changes in interface configuration.
 When this method is in use, 
 GATED rereads the interface list only once a minute. It also rereads it 
 on routing table changes indications and when a SIGUSR2 is received. 
 This interval may be explicitly configured in the interface 
 configuration.
A.16.5 Reading Interface Physical Addresses
Later version of the getkerninfo() and sysctl() interfaces return the 
interface physical addresses as part of the interface information. On 
most systems where this information is not returned, GATED scans the 
kernel physical interface list for this information for interfaces with 
IFFBROADCAST set, assuming that their drivers are handled the same as 
Ethernet drivers. On some systems, system specific interfaces are used 
to learn this information.
The interface physical addresses are useful for IS-IS. For IP 
protocols, they are not currently used, but they may be used in the 
future.
A.16.6 Reading Kernel Variables
At startup, GATED reads some special variables out of the kernel. This 
is usually done with the
nlist
 (or
kvm_nlist
) system call, but some systems use different methods.
The variables read include the status of UDP checksum creation and 
generation, IP forwarding and kernel version (for informational 
purposes). On systems where the routing table is read directly from 
kernel memory, the root of the hash table or radix tree routing table 
is read. On systems where interface physical addresses are not supplied 
by other means, the root of the interface list is read.
A.16.7 Special Route Flags
The later BSD based kernel support the special route flags described in 
the following list:
  - RTF_REJECT 
 Instead of forwarding a packet like a normal route, 
  routes with RTF_REJECT cause packets to be dropped and unreachable 
  messages to be sent to the packet originators. This flag is only valid 
  on routes pointing at the loopback interface.
- RTF_BLACKHOLE 
 Like the RTF_REJECT flag, routes with 
  RTF_BLACKHOLE cause packets to be dropped, but unreachable messages are 
  not sent. This flag is only valid on routes pointing at the loopback 
  interface.
- RTF_STATIC 
 When GATED starts, it reads all the routes currently 
  in the kernel forwarding table. Besides interface routes, it usually 
  marks everything else as a remnant from a previous run of GATED and 
  deletes it after a few minutes. This means that routes added with the 
  ROUTE command will not be retained after GATED has started.
 To fix 
  this the RTF_STATIC flag was added. When the route command is used to 
  install a route that is not an interface route it sets the RTF_STATIC 
  flag. This signals to GATED that the specified route was added by the 
  systems administrator and should be retained.
A.16.8 Kernel Configuration Syntax
The kernel configuration syntax is as follows:
  
    | 
 
kernel { 
    options 
        [ nochange ] 
        [ noflushatexit ] 
        ; 
    routes number ; 
    flash 
        [ limit number ] 
        [ type interface | interior | all ] 
        ; 
    background 
        [ limit number ] 
        [ priority flash | higher | lower ] 
        ; 
    traceoptions trace_options ; 
} ; 
 
 | 
In the kernel configuration syntax:
  - 
options
specifies kernel options. Valid options are:
  
    - 
nochange
, which, on systems supporting the routing socket, ensures that changes 
operations will not be performed, only deletes and adds. This is useful 
on early versions of the routing socket code where the change operation 
was broken.
    
- 
noflushatexit
, which specifies that during normal shutdown processing GATED deletes 
all routes from the kernel forwarding table that do not have a retain 
indication. The
noflushatexit
 option prevents route deletions at shutdown. Instead, routes are 
 changed and added to make sure that all the routes marked with retain 
 get installed. 
 This is useful on systems with thousands of routes. 
 Upon startup GATED will notice which routes are in the kernel 
 forwarding table and not have add them back.
 
- 
routes
specifies the routes number. On some systems kernel memory is at a 
premium. With this parameter a limit can be placed on the maximum 
number of routes GATED will install in the kernel. Normally GATED 
adds/changes/deletes routes in interface/internal/external order, for 
example, it queues interface routes first, followed by internal routes, 
followed by external routes, and processes the queue from the 
beginning. If a this parameter is specified and the limit is hit, GATED 
does two scans of the list instead. On the first scan it does deletes, 
and also deletes all changed routes, turning the queued changes into 
adds. It then rescans the list doing adds in 
interface/internal/external order until it hits the limit again. This 
will tend to favor internal routes over external routes. The default is 
not to limit the number of routes in the kernel forwarding table.
  
- 
flash
specifies that a route has changed. The process of notifying the 
protocols is called a flash update. The kernel forwarding table 
interface is the first to be notified. Normally a maximum of 20 
interface routes may be processed during one flash update. The
flash
 command allows tuning of the following parameters:
  
    - 
limit number
, which specifies the maximum number of routes which may be processed 
during one flash update. The default is 20. A value of -1 will cause 
all pending route changes of the specified type to be processed during 
the flash update.
    
- 
type
, which specifies the type of routes that will be processed during a 
flash update. Interior specifies that interior routes will also be 
installed (see Section A.12.1).
all
 specifies the inclusion of exterior routes as well (see Section A.12.2). 
 The default is
interface
, which specifies that only interface routes will be installed during a 
flash update. 
 Specifying flash limit -1 all causes all routes to be 
installed during the flash update; this mimics the behavior of previous 
versions of GATED.
 
- 
background
specifies that the remaining routes are processed in batches in the 
background, that is, when no routing protocol traffic is being 
received. Normally, 120 routes are installed at a time to allow other 
tasks to be performed and the background processing is done at lower 
priority than flash updates the following parameters allow tuning of 
these parameters:
  
    - 
limit
, which specifies the number of routes which may be processed at during 
one batch. The default is 120.
    
- 
priority
, which specifies the priority of the processing of batches of kernel 
updates in relationship to the flash update processing. The default is
lower
, which means that flash updates are processed first. To process kernel 
updates at the same priority as flash updates, specify
flash
. To process kernel updates at a higher priority, use
higher
.
  
 
A.16.9 Kernel Tracing Options
While the kernel interface is not technically a routing protocol, in 
many cases it is handled as one. You can enter the following two 
symbols from the command line because the code that uses them is 
executed before the trace file is parsed.
  
    | symbols | Symbols read from the kernel, by nlist() or similar interface. | 
  
    | iflist | Interface list scan. This option is useful when entered from the 
       command line as the first interface list scan is performed before the 
       configuration file is parsed. | 
The following tracing options can be specified only in the 
configuration file. They are not valid from the command line.
  
    | remnants | Routes read from the kernel when GATED starts. | 
  
    | request | Requests by GATED to Add/Delete/Change routes in the kernel forwarding 
       table. | 
Use the following general option and packet-tracing options to systems 
that use the routing socket to exchange routing information with the 
kernel. They do not apply to systems that use the old BSD 4.3
ioctl()
 interface to the kernel.
  - 
info
    
 Records informational messages received from the routing socket, 
    such as TCP lossage, routing lookup failure, and route resolution 
    requests. GATED does not currently do processing on these messages, 
    just logs the information if requested.
Packet tracing options (which may be modified with
detail
,
send
, and
recv
) specify the types of message and include:
  - 
routes
    
 Routes exchanged with the kernel, including Add/Delete/Change 
    messages and Add/Delete/Change messages received from other processes.
- 
redirect
    
 Redirect messages received from the kernel.
- 
interface
    
 Interface status messages received from the kernel. These are only 
    supported on systems with networking code derived from BSD 4.4.
- 
other
    
 Other messages received from the kernel, including those mentioned 
    in the info type above.