mirror of
https://gitlab.labs.nic.cz/labs/bird.git
synced 2024-05-11 16:54:54 +00:00
Temporary integrated OSPF commit.
This commit is contained in:
@@ -2,9 +2,10 @@
|
||||
* BIRD -- OSPF
|
||||
*
|
||||
* (c) 2000--2004 Ondrej Filip <feela@network.cz>
|
||||
* (c) 2009--2014 Ondrej Zajicek <santiago@crfreenet.org>
|
||||
* (c) 2009--2014 CZ.NIC z.s.p.o.
|
||||
*
|
||||
* Can be freely distributed and used under the terms of the GNU GPL.
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef _BIRD_OSPF_RT_H_
|
||||
@@ -28,12 +29,17 @@ typedef struct orta
|
||||
#define ORTA_ASBR OPT_RT_E
|
||||
#define ORTA_ABR OPT_RT_B
|
||||
/*
|
||||
* For ORT_NET routes, the field is almost unused with one
|
||||
* exception: ORTA_PREF for external routes means that the route is
|
||||
* preferred in AS external route selection according to 16.4.1. -
|
||||
* it is intra-area path using non-backbone area. In other words,
|
||||
* the forwarding address (or ASBR if forwarding address is zero) is
|
||||
* intra-area (type == RTS_OSPF) and its area is not a backbone.
|
||||
* For ORT_NET routes, there are just several flags for external routes:
|
||||
*
|
||||
* ORTA_PREF for external routes means that the route is preferred in AS
|
||||
* external route selection according to 16.4.1. - it is intra-area path using
|
||||
* non-backbone area. In other words, the forwarding address (or ASBR if
|
||||
* forwarding address is zero) is intra-area (type == RTS_OSPF) and its area
|
||||
* is not a backbone.
|
||||
*
|
||||
* ORTA_NSSA means that the entry represents an NSSA route, and ORTA_PROP
|
||||
* means that the NSSA route has propagate-bit set. These flags are used in
|
||||
* NSSA translation.
|
||||
*/
|
||||
#define ORTA_PREF 0x80000000
|
||||
#define ORTA_NSSA 0x40000000
|
||||
@@ -51,41 +57,38 @@ typedef struct orta
|
||||
}
|
||||
orta;
|
||||
|
||||
|
||||
/* Values for fn.flags in struct ort */
|
||||
#define OSPF_RT_PERSISTENT 0x01
|
||||
|
||||
typedef struct ort
|
||||
{
|
||||
/*
|
||||
* We use OSPF_RT_PERSISTENT to mark persistent rt entries, that are
|
||||
* needed for summary LSAs that don't have 'proper' rt entry (area
|
||||
* networks + default to stubs) to keep uid stable (used for LSA ID
|
||||
* in OSPFv3 - see fibnode_to_lsaid()).
|
||||
* Most OSPF routing table entries are for computed OSPF routes, these have
|
||||
* defined n.type. There are also few other cases: entries for configured area
|
||||
* networks (these have area_net field set) and entries for external routes
|
||||
* exported to OSPF (these have external_rte field set). These entries are
|
||||
* kept even if they do not contain 'proper' rt entry. That is needed to keep
|
||||
* allocated stable UID numbers (fn.uid), which are used as LSA IDs in OSPFv3
|
||||
* (see fibnode_to_lsaid()) for related LSAs (network summary LSAs in the
|
||||
* first case, external or NSSA LSAs in the second case). Entries for external
|
||||
* routes also have a second purpose - to prevent NSSA translation of received
|
||||
* NSSA routes if regular external routes were already originated for the same
|
||||
* network (see check_nssa_lsa()).
|
||||
*
|
||||
* We use ORT_RT_EXPORT and ORT_RT_NSSA to note whether the
|
||||
* external/NSSA route was originated from the route export (in
|
||||
* ospf_rt_notify()) or from the NSSA route translation (in
|
||||
* check_nssa_lsa()).
|
||||
*
|
||||
* old_* values are here to represent the last route update. old_rta
|
||||
* is cached (we keep reference), mainly for multipath nexthops.
|
||||
* old_rta == NULL means route was not in the last update, in that
|
||||
* case other old_* values are not valid.
|
||||
* old_* values are here to represent the last route update. old_rta is cached
|
||||
* (we keep reference), mainly for multipath nexthops. old_rta == NULL means
|
||||
* route was not in the last update, in that case other old_* values are not
|
||||
* valid.
|
||||
*/
|
||||
struct fib_node fn;
|
||||
orta n;
|
||||
u32 old_metric1, old_metric2, old_tag, old_rid;
|
||||
rta *old_rta;
|
||||
u8 external_rte;
|
||||
u8 area_net;
|
||||
}
|
||||
ort;
|
||||
|
||||
static inline int rt_is_nssa(ort *nf)
|
||||
{ return nf->n.options & ORTA_NSSA; }
|
||||
|
||||
#define EXT_EXPORT 1
|
||||
#define EXT_NSSA 2
|
||||
|
||||
/*
|
||||
* Invariants for structs top_hash_entry (nodes of LSA db)
|
||||
@@ -97,7 +100,7 @@ static inline int rt_is_nssa(ort *nf)
|
||||
* - beware, nhs is not valid after SPF calculation
|
||||
*
|
||||
* Invariants for structs orta nodes of fib tables po->rtf, oa->rtr:
|
||||
* - nodes may be invalid (fn.type == 0), in that case other invariants don't hold
|
||||
* - nodes may be invalid (n.type == 0), in that case other invariants don't hold
|
||||
* - n.metric1 may be at most a small multiple of LSINFINITY,
|
||||
* therefore sums do not overflow
|
||||
* - n.oa is always non-NULL
|
||||
|
||||
Reference in New Issue
Block a user