FreeBSD manual
download PDF document: rtentry.9.pdf
RTENTRY(9) FreeBSD Kernel Developer's Manual RTENTRY(9)
NAME
rtentry - structure of an entry in the kernel routing table
SYNOPSIS
#include <sys/types.h>
#include <sys/socket.h>
#include <net/route.h>
DESCRIPTION
The kernel provides a common mechanism by which all protocols can store
and retrieve entries from a central table of routes. Parts of this
mechanism are also used to interact with user-level processes by means of
a socket in the route(4) pseudo-protocol family. The <net/route.h>
header file defines the structures and manifest constants used in this
facility.
The basic structure of a route is defined by struct rtentry, which
includes the following fields:
struct radix_node rt_nodes[2];
Glue used by the radix-tree routines. These members also
include in their substructure the key (i.e., destination
address) and mask used when the route was created. The
rt_key(rt) and rt_mask(rt) macros can be used to extract
this information (in the form of a struct sockaddr *) given
a struct rtentry *.
struct sockaddr *rt_gateway;
The "target" of the route, which can either represent a
destination in its own right (some protocols will put a
link-layer address here), or some intermediate stop on the
way to that destination (if the RTF_GATEWAY flag is set).
int rt_flags;
See below. If the RTF_UP flag is not present, the rtfree()
function will delete the route from the radix tree when the
last reference drops.
int rt_refcnt;
Route entries are reference-counted; this field indicates
the number of external (to the radix tree) references.
struct ifnet *rt_ifp;
struct ifaddr *rt_ifa;
These two fields represent the "answer", as it were, to the
question posed by a route lookup; that is, they name the
interface and interface address to be used in sending a
packet to the destination or set of destinations which this
route represents.
u_long rt_mtu;
See description of rmx_mtu below.
u_long rt_weight;
See description of rmx_weight below.
This member is a reference to a route whose destination is
rt_gateway. It is only used for RTF_GATEWAY routes.
struct mtx rt_mtx;
Mutex to lock this routing entry.
The following flag bits are defined:
RTF_UP The route is not deleted.
RTF_GATEWAY The route points to an intermediate destination and
not the ultimate recipient; the rt_gateway and
rt_gwroute fields name that destination.
RTF_HOST This is a host route.
RTF_REJECT The destination is presently unreachable. This
should result in an EHOSTUNREACH error from output
routines.
RTF_DYNAMIC This route was created dynamically by rtredirect().
RTF_MODIFIED This route was modified by rtredirect().
RTF_DONE Used only in the route(4) protocol, indicating that
the request was executed.
RTF_XRESOLVE When this route is returned as a result of a lookup,
send a report on the route(4) interface requesting
that an external process perform resolution for this
route.
RTF_STATIC Indicates that this route was manually added by
means of the route(8) command.
RTF_BLACKHOLE Requests that output sent via this route be
discarded.
RTF_PROTO1
RTF_PROTO2
RTF_PROTO3 Protocol-specific.
RTF_PINNED Indicates that this route is immutable to a routing
protocol.
RTF_LOCAL Indicates that the destination of this route is an
address configured as belonging to this system.
RTF_BROADCAST Indicates that the destination is a broadcast
address.
RTF_MULTICAST Indicates that the destination is a multicast
address.
Several metrics are supplied in struct rt_metrics passed with routing
control messages via route(4) API. Currently only rmx_mtu, rmx_expire,
and rmx_pksent metrics are supplied. All others are ignored.
The following metrics are defined by struct rt_metrics:
u_long rmx_locks;
Flag bits indicating which metrics the kernel is not
permitted to dynamically modify.
u_long rmx_mtu;
MTU for this path.
u_long rmx_hopcount;
Number of intermediate systems on the path to this
destination.
u_long rmx_expire;
The time (a la time(3)) at which this route should expire,
or zero if it should never expire. It is the
window in sliding-window protocols like TCP).
u_long rmx_sendpipe;
As before, but in the opposite direction.
u_long rmx_ssthresh;
The slow-start threshold used in TCP congestion-avoidance.
u_long rmx_rtt;
The round-trip time to this destination, in units of
RMX_RTTUNIT per second.
u_long rmx_rttvar;
The average deviation of the round-trip time to this
destination, in units of RMX_RTTUNIT per second.
u_long rmx_pksent;
A count of packets successfully sent via this route.
u_long rmx_filler[4];
Empty space available for protocol-specific information.
SEE ALSO
route(4), route(8),
HISTORY
The rtentry structure first appeared in 4.2BSD. The radix-tree
representation of the routing table and the rt_metrics structure first
appeared in 4.3BSD-Reno.
AUTHORS
This manual page was written by Garrett Wollman.
BUGS
There are a number of historical relics remaining in this interface. The
rt_gateway and rmx_filler fields could be named better.
FreeBSD 14.2-RELEASE March 5, 2014 FreeBSD 14.2-RELEASE