Annotation of embedaddon/bird2/proto/ospf/rt.h, revision 1.1

1.1     ! misho       1: /*
        !             2:  *      BIRD -- OSPF
        !             3:  *
        !             4:  *      (c) 2000--2004 Ondrej Filip <feela@network.cz>
        !             5:  *     (c) 2009--2014 Ondrej Zajicek <santiago@crfreenet.org>
        !             6:  *     (c) 2009--2014 CZ.NIC z.s.p.o.
        !             7:  *
        !             8:  *      Can be freely distributed and used under the terms of the GNU GPL.
        !             9:  */
        !            10: 
        !            11: #ifndef _BIRD_OSPF_RT_H_
        !            12: #define _BIRD_OSPF_RT_H_
        !            13: 
        !            14: 
        !            15: #define ORT_NET 0
        !            16: #define ORT_ROUTER 1
        !            17: 
        !            18: typedef struct orta
        !            19: {
        !            20:   u8 type;                     /* RTS_OSPF_* */
        !            21:   u8 nhs_reuse;                        /* Whether nhs nodes can be reused during merging.
        !            22:                                   See a note in rt.c:add_cand() */
        !            23:   u32 options;
        !            24:   /*
        !            25:    * For ORT_ROUTER routes, options field are router-LSA style
        !            26:    * options, with V,E,B bits. In OSPFv2, ASBRs from another areas
        !            27:    * (that we know from rt-summary-lsa) have just ORTA_ASBR in
        !            28:    * options, their real options are unknown.
        !            29:    */
        !            30: #define ORTA_ASBR OPT_RT_E
        !            31: #define ORTA_ABR  OPT_RT_B
        !            32:   /*
        !            33:    * For ORT_NET routes, there are just several flags for external routes:
        !            34:    *
        !            35:    * ORTA_PREF for external routes means that the route is preferred in AS
        !            36:    * external route selection according to 16.4.1. - it is intra-area path using
        !            37:    * non-backbone area. In other words, the forwarding address (or ASBR if
        !            38:    * forwarding address is zero) is intra-area (type == RTS_OSPF) and its area
        !            39:    * is not a backbone.
        !            40:    *
        !            41:    * ORTA_NSSA means that the entry represents an NSSA route, and ORTA_PROP
        !            42:    * means that the NSSA route has propagate-bit set. These flags are used in
        !            43:    * NSSA translation.
        !            44:    */
        !            45: #define ORTA_PREF 0x80000000
        !            46: #define ORTA_NSSA 0x40000000
        !            47: #define ORTA_PROP 0x20000000
        !            48: 
        !            49:   u32 metric1;
        !            50:   u32 metric2;
        !            51:   u32 tag;
        !            52:   u32 rid;                     /* Router ID of real advertising router */
        !            53:   struct ospf_area *oa;
        !            54:   struct ospf_area *voa;       /* Used when route is replaced in ospf_rt_sum_tr(),
        !            55:                                   NULL otherwise */
        !            56:   struct nexthop *nhs;         /* Next hops computed during SPF */
        !            57:   struct top_hash_entry *en;   /* LSA responsible for this orta */
        !            58: }
        !            59: orta;
        !            60: 
        !            61: typedef struct ort
        !            62: {
        !            63:   /*
        !            64:    * Most OSPF routing table entries are for computed OSPF routes, these have
        !            65:    * defined n.type. There are also few other cases: entries for configured area
        !            66:    * networks (these have area_net field set) and entries for external routes
        !            67:    * exported to OSPF (these have external_rte field set). These entries are
        !            68:    * kept even if they do not contain 'proper' rt entry. That is needed to keep
        !            69:    * allocated stable UID numbers (fn.uid), which are used as LSA IDs in OSPFv3
        !            70:    * (see fibnode_to_lsaid()) for related LSAs (network summary LSAs in the
        !            71:    * first case, external or NSSA LSAs in the second case). Entries for external
        !            72:    * routes also have a second purpose - to prevent NSSA translation of received
        !            73:    * NSSA routes if regular external routes were already originated for the same
        !            74:    * network (see check_nssa_lsa()).
        !            75:    *
        !            76:    * old_* values are here to represent the last route update. old_rta is cached
        !            77:    * (we keep reference), mainly for multipath nexthops.  old_rta == NULL means
        !            78:    * route was not in the last update, in that case other old_* values are not
        !            79:    * valid.
        !            80:    */
        !            81:   orta n;
        !            82:   u32 old_metric1, old_metric2, old_tag, old_rid;
        !            83:   rta *old_rta;
        !            84:   u32 lsa_id;
        !            85:   u8 external_rte;
        !            86:   u8 area_net;
        !            87:   u8 keep;
        !            88: 
        !            89:   struct fib_node fn;
        !            90: }
        !            91: ort;
        !            92: 
        !            93: static inline int rt_is_nssa(ort *nf)
        !            94: { return nf->n.options & ORTA_NSSA; }
        !            95: 
        !            96: 
        !            97: /*
        !            98:  * Invariants for structs top_hash_entry (nodes of LSA db)
        !            99:  * enforced by SPF calculation for final nodes (color == INSPF):
        !           100:  * - only router, network and AS-external LSAs
        !           101:  * - lsa.age < LSA_MAXAGE
        !           102:  * - dist < LSINFINITY (or 2*LSINFINITY for ext-LSAs)
        !           103:  * - nhs is non-NULL unless the node is oa->rt (calculating router itself)
        !           104:  * - beware, nhs is not valid after SPF calculation
        !           105:  *
        !           106:  * Invariants for structs orta nodes of fib tables po->rtf, oa->rtr:
        !           107:  * - nodes may be invalid (n.type == 0), in that case other invariants don't hold
        !           108:  * - n.metric1 may be at most a small multiple of LSINFINITY,
        !           109:  *   therefore sums do not overflow
        !           110:  * - n.oa is always non-NULL
        !           111:  * - n.nhs is always non-NULL unless it is configured stubnet
        !           112:  * - n.en is non-NULL for external routes, NULL for intra/inter area routes.
        !           113:  * - oa->rtr does not contain calculating router itself
        !           114:  *
        !           115:  * There are four types of nexthops in nhs fields:
        !           116:  * - gateway nexthops (non-NULL iface, gw != IPA_NONE)
        !           117:  * - device nexthops (non-NULL iface, gw == IPA_NONE)
        !           118:  * - dummy vlink nexthops (NULL iface, gw == IPA_NONE)
        !           119:  * - configured stubnets (nhs is NULL, only RTS_OSPF orta nodes in po->rtf)
        !           120:  *
        !           121:  * Dummy vlink nexthops and configured stubnets cannot be mixed with
        !           122:  * regular ones, nhs field contains either list of gateway+device nodes,
        !           123:  * one vlink node, or NULL for configured stubnet.
        !           124:  *
        !           125:  * Dummy vlink nexthops can appear in both network (rtf) and backbone area router
        !           126:  * (rtr) tables for regular and inter-area routes, but only if areano > 1. They are
        !           127:  * replaced in ospf_rt_sum_tr() and removed in ospf_rt_abr1(), therefore cannot
        !           128:  * appear in ASBR pre-selection and external routes processing.
        !           129:  */
        !           130: 
        !           131: void ospf_rt_spf(struct ospf_proto *p);
        !           132: void ospf_rt_initort(struct fib_node *fn);
        !           133: void ospf_update_gr_recovery(struct ospf_proto *p);
        !           134: 
        !           135: 
        !           136: #endif /* _BIRD_OSPF_RT_H_ */

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>