Annotation of XNU/bsd/net/route.h, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
                      3:  *
                      4:  * @APPLE_LICENSE_HEADER_START@
                      5:  * 
                      6:  * The contents of this file constitute Original Code as defined in and
                      7:  * are subject to the Apple Public Source License Version 1.1 (the
                      8:  * "License").  You may not use this file except in compliance with the
                      9:  * License.  Please obtain a copy of the License at
                     10:  * http://www.apple.com/publicsource and read it before using this file.
                     11:  * 
                     12:  * This Original Code and all software distributed under the License are
                     13:  * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
                     14:  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
                     15:  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
                     16:  * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT.  Please see the
                     17:  * License for the specific language governing rights and limitations
                     18:  * under the License.
                     19:  * 
                     20:  * @APPLE_LICENSE_HEADER_END@
                     21:  */
                     22: /*
                     23:  * Copyright (c) 1980, 1986, 1993
                     24:  *     The Regents of the University of California.  All rights reserved.
                     25:  *
                     26:  * Redistribution and use in source and binary forms, with or without
                     27:  * modification, are permitted provided that the following conditions
                     28:  * are met:
                     29:  * 1. Redistributions of source code must retain the above copyright
                     30:  *    notice, this list of conditions and the following disclaimer.
                     31:  * 2. Redistributions in binary form must reproduce the above copyright
                     32:  *    notice, this list of conditions and the following disclaimer in the
                     33:  *    documentation and/or other materials provided with the distribution.
                     34:  * 3. All advertising materials mentioning features or use of this software
                     35:  *    must display the following acknowledgement:
                     36:  *     This product includes software developed by the University of
                     37:  *     California, Berkeley and its contributors.
                     38:  * 4. Neither the name of the University nor the names of its contributors
                     39:  *    may be used to endorse or promote products derived from this software
                     40:  *    without specific prior written permission.
                     41:  *
                     42:  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
                     43:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
                     44:  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
                     45:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
                     46:  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
                     47:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
                     48:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
                     49:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
                     50:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
                     51:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
                     52:  * SUCH DAMAGE.
                     53:  *
                     54:  *     @(#)route.h     8.3 (Berkeley) 4/19/94
                     55:  */
                     56: 
                     57: #ifndef _NET_ROUTE_H_
                     58: #define _NET_ROUTE_H_
                     59: 
                     60: /*
                     61:  * Kernel resident routing tables.
                     62:  *
                     63:  * The routing tables are initialized when interface addresses
                     64:  * are set by making entries for all directly connected interfaces.
                     65:  */
                     66: 
                     67: /*
                     68:  * A route consists of a destination address and a reference
                     69:  * to a routing entry.  These are often held by protocols
                     70:  * in their control blocks, e.g. inpcb.
                     71:  */
                     72: struct route {
                     73:        struct  rtentry *ro_rt;
                     74:        struct  sockaddr ro_dst;
                     75: };
                     76: 
                     77: /*
                     78:  * These numbers are used by reliable protocols for determining
                     79:  * retransmission behavior and are included in the routing structure.
                     80:  */
                     81: struct rt_metrics {
                     82:        u_long  rmx_locks;      /* Kernel must leave these values alone */
                     83:        u_long  rmx_mtu;        /* MTU for this path */
                     84:        u_long  rmx_hopcount;   /* max hops expected */
                     85:        u_long  rmx_expire;     /* lifetime for route, e.g. redirect */
                     86:        u_long  rmx_recvpipe;   /* inbound delay-bandwidth product */
                     87:        u_long  rmx_sendpipe;   /* outbound delay-bandwidth product */
                     88:        u_long  rmx_ssthresh;   /* outbound gateway buffer limit */
                     89:        u_long  rmx_rtt;        /* estimated round trip time */
                     90:        u_long  rmx_rttvar;     /* estimated rtt variance */
                     91:        u_long  rmx_pksent;     /* packets sent using this route */
                     92:        u_long  rmx_filler[4];  /* will be used for T/TCP later */
                     93: };
                     94: 
                     95: /*
                     96:  * rmx_rtt and rmx_rttvar are stored as microseconds;
                     97:  * RTTTOPRHZ(rtt) converts to a value suitable for use
                     98:  * by a protocol slowtimo counter.
                     99:  */
                    100: #define        RTM_RTTUNIT     1000000 /* units for rtt, rttvar, as units per sec */
                    101: #define        RTTTOPRHZ(r)    ((r) / (RTM_RTTUNIT / PR_SLOWHZ))
                    102: 
                    103: /*
                    104:  * XXX kernel function pointer `rt_output' is visible to applications.
                    105:  */
                    106: struct mbuf;
                    107: 
                    108: /*
                    109:  * We distinguish between routes to hosts and routes to networks,
                    110:  * preferring the former if available.  For each route we infer
                    111:  * the interface to use from the gateway address supplied when
                    112:  * the route was entered.  Routes that forward packets through
                    113:  * gateways are marked so that the output routines know to address the
                    114:  * gateway rather than the ultimate destination.
                    115:  */
                    116: #ifndef RNF_NORMAL
                    117: #include <net/radix.h>
                    118: #endif
                    119: struct rtentry {
                    120:        struct  radix_node rt_nodes[2]; /* tree glue, and other values */
                    121: #define        rt_key(r)       ((struct sockaddr *)((r)->rt_nodes->rn_key))
                    122: #define        rt_mask(r)      ((struct sockaddr *)((r)->rt_nodes->rn_mask))
                    123:        struct  sockaddr *rt_gateway;   /* value */
                    124:        short   rt_filler;              /* was short flags field */
                    125:        short   rt_refcnt;              /* # held references */
                    126:        u_long  rt_flags;               /* up/down?, host/net */
                    127:        struct  ifnet *rt_ifp;          /* the answer: interface to use */
                    128:         u_long  rt_dlt;                        /* DLIL dl_tag */
                    129:        struct  ifaddr *rt_ifa;         /* the answer: interface to use */
                    130:        struct  sockaddr *rt_genmask;   /* for generation of cloned routes */
                    131:        caddr_t rt_llinfo;              /* pointer to link level info cache */
                    132:        struct  rt_metrics rt_rmx;      /* metrics used by rx'ing protocols */
                    133:        struct  rtentry *rt_gwroute;    /* implied entry for gatewayed routes */
                    134:        int     (*rt_output) __P((struct ifnet *, struct mbuf *,
                    135:                                  struct sockaddr *, struct rtentry *));
                    136:                                        /* output routine for this (rt,if) */
                    137:        struct  rtentry *rt_parent;     /* cloning parent of this route */
                    138:        void    *rt_filler2;            /* more filler */
                    139: };
                    140: 
                    141: /*
                    142:  * Following structure necessary for 4.3 compatibility;
                    143:  * We should eventually move it to a compat file.
                    144:  */
                    145: struct ortentry {
                    146:        u_long  rt_hash;                /* to speed lookups */
                    147:        struct  sockaddr rt_dst;        /* key */
                    148:        struct  sockaddr rt_gateway;    /* value */
                    149:        short   rt_flags;               /* up/down?, host/net */
                    150:        short   rt_refcnt;              /* # held references */
                    151:        u_long  rt_use;                 /* raw # packets forwarded */
                    152:        struct  ifnet *rt_ifp;          /* the answer: interface to use */
                    153: };
                    154: 
                    155: #define rt_use rt_rmx.rmx_pksent
                    156: 
                    157: #define        RTF_UP          0x1             /* route usable */
                    158: #define        RTF_GATEWAY     0x2             /* destination is a gateway */
                    159: #define        RTF_HOST        0x4             /* host entry (net otherwise) */
                    160: #define        RTF_REJECT      0x8             /* host or net unreachable */
                    161: #define        RTF_DYNAMIC     0x10            /* created dynamically (by redirect) */
                    162: #define        RTF_MODIFIED    0x20            /* modified dynamically (by redirect) */
                    163: #define RTF_DONE       0x40            /* message confirmed */
                    164: /*                     0x80               unused */
                    165: #define RTF_CLONING    0x100           /* generate new routes on use */
                    166: #define RTF_XRESOLVE   0x200           /* external daemon resolves name */
                    167: #define RTF_LLINFO     0x400           /* generated by link layer (e.g. ARP) */
                    168: #define RTF_STATIC     0x800           /* manually added */
                    169: #define RTF_BLACKHOLE  0x1000          /* just discard pkts (during updates) */
                    170: #define RTF_PROTO2     0x4000          /* protocol specific routing flag */
                    171: #define RTF_PROTO1     0x8000          /* protocol specific routing flag */
                    172: 
                    173: #define RTF_PRCLONING  0x10000         /* protocol requires cloning */
                    174: #define RTF_WASCLONED  0x20000         /* route generated through cloning */
                    175: #define RTF_PROTO3     0x40000         /* protocol specific routing flag */
                    176: /*                     0x80000            unused */
                    177: #define RTF_PINNED     0x100000        /* future use */
                    178: #define        RTF_LOCAL       0x200000        /* route represents a local address */
                    179: #define        RTF_BROADCAST   0x400000        /* route represents a bcast address */
                    180: #define        RTF_MULTICAST   0x800000        /* route represents a mcast address */
                    181:                                        /* 0x1000000 and up unassigned */
                    182: 
                    183: /*
                    184:  * Routing statistics.
                    185:  */
                    186: struct rtstat {
                    187:        short   rts_badredirect;        /* bogus redirect calls */
                    188:        short   rts_dynamic;            /* routes created by redirects */
                    189:        short   rts_newgateway;         /* routes modified by redirects */
                    190:        short   rts_unreach;            /* lookups which failed */
                    191:        short   rts_wildcard;           /* lookups satisfied by a wildcard */
                    192: };
                    193: /*
                    194:  * Structures for routing messages.
                    195:  */
                    196: struct rt_msghdr {
                    197:        u_short rtm_msglen;     /* to skip over non-understood messages */
                    198:        u_char  rtm_version;    /* future binary compatibility */
                    199:        u_char  rtm_type;       /* message type */
                    200:        u_short rtm_index;      /* index for associated ifp */
                    201:        int     rtm_flags;      /* flags, incl. kern & message, e.g. DONE */
                    202:        int     rtm_addrs;      /* bitmask identifying sockaddrs in msg */
                    203:        pid_t   rtm_pid;        /* identify sender */
                    204:        int     rtm_seq;        /* for sender to identify action */
                    205:        int     rtm_errno;      /* why failed */
                    206:        int     rtm_use;        /* from rtentry */
                    207:        u_long  rtm_inits;      /* which metrics we are initializing */
                    208:        struct  rt_metrics rtm_rmx; /* metrics themselves */
                    209: };
                    210: 
                    211: #define RTM_VERSION    5       /* Up the ante and ignore older versions */
                    212: 
                    213: /*
                    214:  * Message types.
                    215:  */
                    216: #define RTM_ADD                0x1     /* Add Route */
                    217: #define RTM_DELETE     0x2     /* Delete Route */
                    218: #define RTM_CHANGE     0x3     /* Change Metrics or flags */
                    219: #define RTM_GET                0x4     /* Report Metrics */
                    220: #define RTM_LOSING     0x5     /* Kernel Suspects Partitioning */
                    221: #define RTM_REDIRECT   0x6     /* Told to use different route */
                    222: #define RTM_MISS       0x7     /* Lookup failed on this address */
                    223: #define RTM_LOCK       0x8     /* fix specified metrics */
                    224: #define RTM_OLDADD     0x9     /* caused by SIOCADDRT */
                    225: #define RTM_OLDDEL     0xa     /* caused by SIOCDELRT */
                    226: #define RTM_RESOLVE    0xb     /* req to resolve dst to LL addr */
                    227: #define RTM_NEWADDR    0xc     /* address being added to iface */
                    228: #define RTM_DELADDR    0xd     /* address being removed from iface */
                    229: #define RTM_IFINFO     0xe     /* iface going up/down etc. */
                    230: #define        RTM_NEWMADDR    0xf     /* mcast group membership being added to if */
                    231: #define        RTM_DELMADDR    0x10    /* mcast group membership being deleted */
                    232: 
                    233: /*
                    234:  * Bitmask values for rtm_inits and rmx_locks.
                    235:  */
                    236: #define RTV_MTU                0x1     /* init or lock _mtu */
                    237: #define RTV_HOPCOUNT   0x2     /* init or lock _hopcount */
                    238: #define RTV_EXPIRE     0x4     /* init or lock _expire */
                    239: #define RTV_RPIPE      0x8     /* init or lock _recvpipe */
                    240: #define RTV_SPIPE      0x10    /* init or lock _sendpipe */
                    241: #define RTV_SSTHRESH   0x20    /* init or lock _ssthresh */
                    242: #define RTV_RTT                0x40    /* init or lock _rtt */
                    243: #define RTV_RTTVAR     0x80    /* init or lock _rttvar */
                    244: 
                    245: /*
                    246:  * Bitmask values for rtm_addrs.
                    247:  */
                    248: #define RTA_DST                0x1     /* destination sockaddr present */
                    249: #define RTA_GATEWAY    0x2     /* gateway sockaddr present */
                    250: #define RTA_NETMASK    0x4     /* netmask sockaddr present */
                    251: #define RTA_GENMASK    0x8     /* cloning mask sockaddr present */
                    252: #define RTA_IFP                0x10    /* interface name sockaddr present */
                    253: #define RTA_IFA                0x20    /* interface addr sockaddr present */
                    254: #define RTA_AUTHOR     0x40    /* sockaddr for author of redirect */
                    255: #define RTA_BRD                0x80    /* for NEWADDR, broadcast or p-p dest addr */
                    256: 
                    257: /*
                    258:  * Index offsets for sockaddr array for alternate internal encoding.
                    259:  */
                    260: #define RTAX_DST       0       /* destination sockaddr present */
                    261: #define RTAX_GATEWAY   1       /* gateway sockaddr present */
                    262: #define RTAX_NETMASK   2       /* netmask sockaddr present */
                    263: #define RTAX_GENMASK   3       /* cloning mask sockaddr present */
                    264: #define RTAX_IFP       4       /* interface name sockaddr present */
                    265: #define RTAX_IFA       5       /* interface addr sockaddr present */
                    266: #define RTAX_AUTHOR    6       /* sockaddr for author of redirect */
                    267: #define RTAX_BRD       7       /* for NEWADDR, broadcast or p-p dest addr */
                    268: #define RTAX_MAX       8       /* size of array to allocate */
                    269: 
                    270: struct rt_addrinfo {
                    271:        int     rti_addrs;
                    272:        struct  sockaddr *rti_info[RTAX_MAX];
                    273: };
                    274: 
                    275: struct route_cb {
                    276:        int     ip_count;
                    277:        int     ipx_count;
                    278:        int     ns_count;
                    279:        int     iso_count;
                    280:        int     any_count;
                    281: };
                    282: 
                    283: #ifdef KERNEL
                    284: #define        RTFREE(rt) \
                    285:        if ((rt)->rt_refcnt <= 1) \
                    286:                rtfree(rt); \
                    287:        else \
                    288:                (rt)->rt_refcnt--;
                    289: #define RTHOLD(rt) {                    \
                    290:         if (++(rt)->rt_refcnt <= 0)    \
                    291:                 panic("RTHOLD");       \
                    292: }
                    293: 
                    294: extern struct route_cb route_cb;
                    295: extern struct radix_node_head *rt_tables[AF_MAX+1];
                    296: 
                    297: struct ifmultiaddr;
                    298: struct proc;
                    299: 
                    300: void    route_init __P((void));
                    301: void    rt_ifmsg __P((struct ifnet *));
                    302: void    rt_missmsg __P((int, struct rt_addrinfo *, int, int));
                    303: void    rt_newaddrmsg __P((int, struct ifaddr *, int, struct rtentry *));
                    304: void    rt_newmaddrmsg __P((int, struct ifmultiaddr *));
                    305: int     rt_setgate __P((struct rtentry *,
                    306:            struct sockaddr *, struct sockaddr *));
                    307: void    rtalloc __P((struct route *));
                    308: void    rtalloc_ign __P((struct route *, unsigned long));
                    309: struct rtentry *
                    310:         rtalloc1 __P((struct sockaddr *, int, unsigned long));
                    311: void    rtfree __P((struct rtentry *));
                    312: int     rtinit __P((struct ifaddr *, int, int));
                    313: int     rtioctl __P((int, caddr_t, struct proc *));
                    314: void    rtredirect __P((struct sockaddr *, struct sockaddr *,
                    315:            struct sockaddr *, int, struct sockaddr *, struct rtentry **));
                    316: int     rtrequest __P((int, struct sockaddr *,
                    317:            struct sockaddr *, struct sockaddr *, int, struct rtentry **));
                    318: #endif
                    319: 
                    320: #endif

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.