]> git.ipfire.org Git - thirdparty/bird.git/blame - nest/iface.h
Filter: Instruction codes named as enum
[thirdparty/bird.git] / nest / iface.h
CommitLineData
58ef912c
MM
1/*
2 * BIRD Internet Routing Daemon -- Network Interfaces
3 *
cf318e3c 4 * (c) 1998--2000 Martin Mares <mj@ucw.cz>
58ef912c
MM
5 *
6 * Can be freely distributed and used under the terms of the GNU GPL.
7 */
8
9#ifndef _BIRD_IFACE_H_
10#define _BIRD_IFACE_H_
11
1feea03e 12#include "lib/lists.h"
c40e05a0 13
8a48ecb8
MM
14extern list iface_list;
15
47b79306 16struct proto;
85053fce 17struct pool;
47b79306 18
9a158361
MM
19struct ifa { /* Interface address */
20 node n;
21 struct iface *iface; /* Interface this address belongs to */
22 ip_addr ip; /* IP address of this host */
23 ip_addr prefix; /* Network prefix */
24 unsigned pxlen; /* Prefix length */
25 ip_addr brd; /* Broadcast address */
26 ip_addr opposite; /* Opposite end of a point-to-point link */
27 unsigned scope; /* Interface address scope */
28 unsigned flags; /* Analogous to iface->flags */
29};
30
c40e05a0
MM
31struct iface {
32 node n;
8a48ecb8 33 char name[16];
c40e05a0 34 unsigned flags;
a8b60382 35 unsigned mtu;
b53499cd 36 unsigned index; /* OS-dependent interface index */
943478b0 37 unsigned master_index; /* Interface index of master iface */
9a158361
MM
38 list addrs; /* Addresses assigned to this interface */
39 struct ifa *addr; /* Primary address */
943478b0 40 struct iface *master; /* Master iface (e.g. for VRF) */
f5ad9f87 41 list neighbors; /* All neighbors on this interface */
c40e05a0
MM
42};
43
f25cb0ef 44#define IF_UP 1 /* IF_ADMIN_UP and IP address known */
c40e05a0 45#define IF_MULTIACCESS 2
6a636392
MM
46#define IF_BROADCAST 4
47#define IF_MULTICAST 8
f25cb0ef 48#define IF_SHUTDOWN 0x10 /* Interface disappeared */
6a636392
MM
49#define IF_LOOPBACK 0x20
50#define IF_IGNORE 0x40 /* Not to be used by routing protocols (loopbacks etc.) */
01427d3f
OZ
51#define IF_ADMIN_UP 0x80 /* Administrative up (e.g. IFF_UP in Linux) */
52#define IF_LINK_UP 0x100 /* Link available (e.g. IFF_LOWER_UP in Linux) */
9a158361
MM
53
54#define IA_PRIMARY 0x10000 /* This address is primary */
55#define IA_SECONDARY 0x20000 /* This address has been reported as secondary by the kernel */
52a43ae3
OZ
56#define IA_PEER 0x40000 /* A peer/ptp address */
57#define IA_HOST 0x80000 /* A host/loopback address */
9a158361
MM
58#define IA_FLAGS 0xff0000
59
52a43ae3
OZ
60/*
61 * There are three kinds of addresses in BIRD:
62 * - Standard (prefix-based) addresses, these may define ifa.opposite (for /30 or /31).
63 * - Peer/ptp addresses, without common prefix for ifa.ip and ifa.opposite.
64 * ifa.opposite is defined and ifa.prefix/pxlen == ifa.opposite/32 (for simplicity).
65 * - Host addresses, with ifa.prefix/pxlen == ifa.ip/32 (or /128).
66 * May be considered a special case of standard addresses.
67 *
489c308a
OZ
68 * Peer addresses (AFAIK) do not exist in IPv6. Linux also supports generalized peer
69 * addresses (with pxlen < 32 and ifa.ip outside prefix), we do not support that.
52a43ae3
OZ
70 */
71
72
9a158361
MM
73#define IF_JUST_CREATED 0x10000000 /* Send creation event as soon as possible */
74#define IF_TMP_DOWN 0x20000000 /* Temporary shutdown due to interface reconfiguration */
bcbd8cc3 75#define IF_UPDATED 0x40000000 /* Touched in last scan */
c40e05a0 76
8a48ecb8
MM
77/* Interface change events */
78
79#define IF_CHANGE_UP 1
80#define IF_CHANGE_DOWN 2
9a158361
MM
81#define IF_CHANGE_MTU 4
82#define IF_CHANGE_CREATE 8 /* Seen this interface for the first time */
f25cb0ef 83#define IF_CHANGE_LINK 0x10
9a158361 84#define IF_CHANGE_TOO_MUCH 0x40000000 /* Used internally */
8a48ecb8
MM
85
86void if_init(void);
87void if_dump(struct iface *);
88void if_dump_all(void);
9a158361 89void ifa_dump(struct ifa *);
ae97b946
MM
90void if_show(void);
91void if_show_summary(void);
9a158361 92struct iface *if_update(struct iface *);
732a0a25 93void if_delete(struct iface *old);
9a158361
MM
94struct ifa *ifa_update(struct ifa *);
95void ifa_delete(struct ifa *);
e35ef181 96void if_start_update(void);
9a158361 97void if_end_partial_update(struct iface *);
53434e44
OZ
98void if_end_update(void);
99void if_flush_ifaces(struct proto *p);
47b79306 100void if_feed_baby(struct proto *);
e35ef181 101struct iface *if_find_by_index(unsigned);
9a158361 102struct iface *if_find_by_name(char *);
69a8259c 103struct iface *if_get_by_name(char *);
874b8685 104void ifa_recalc_all_primary_addresses(void);
8a48ecb8 105
79b4e12e 106
cf318e3c 107/* The Neighbor Cache */
4cc78c50
MM
108
109typedef struct neighbor {
110 node n; /* Node in global neighbor list */
f5ad9f87 111 node if_n; /* Node in per-interface neighbor list */
4cc78c50 112 ip_addr addr; /* Address of the neighbor */
2d0b7e24 113 struct ifa *ifa; /* Ifa on related iface */
2a900b1b 114 struct iface *iface; /* Interface it's connected to */
4cc78c50
MM
115 struct proto *proto; /* Protocol this belongs to */
116 void *data; /* Protocol-specific data */
5954dcfa 117 unsigned aux; /* Protocol-specific data */
4cc78c50 118 unsigned flags;
69a8259c
OZ
119 int scope; /* Address scope, -1 for unreachable sticky neighbors,
120 SCOPE_HOST when it's our own address */
4cc78c50
MM
121} neighbor;
122
123#define NEF_STICKY 1
ff2857b0 124#define NEF_ONLINK 2
69a8259c 125#define NEF_BIND 4 /* Used internally for neighbors bound to an iface */
4cc78c50 126
4cc78c50 127neighbor *neigh_find(struct proto *, ip_addr *, unsigned flags);
be862406 128neighbor *neigh_find2(struct proto *p, ip_addr *a, struct iface *ifa, unsigned flags);
4cc78c50 129
200accf3
MM
130static inline int neigh_connected_to(struct proto *p, ip_addr *a, struct iface *i)
131{
132 neighbor *n = neigh_find(p, a, 0);
133 return n && n->iface == i;
134}
135
4cc78c50
MM
136void neigh_dump(neighbor *);
137void neigh_dump_all(void);
783f8b68 138void neigh_prune(void);
85053fce
MM
139void neigh_if_up(struct iface *);
140void neigh_if_down(struct iface *);
fe181e7c 141void neigh_if_link(struct iface *);
cf7f0645 142void neigh_ifa_update(struct ifa *);
85053fce 143void neigh_init(struct pool *);
4cc78c50 144
ed45f2e1
MM
145/*
146 * Interface Pattern Lists
147 */
148
20e94fb8 149struct iface_patt_node {
ed45f2e1 150 node n;
20e94fb8
OZ
151 int positive;
152 byte *pattern;
153 ip_addr prefix;
8edf2361 154 int pxlen;
20e94fb8
OZ
155};
156
157struct iface_patt {
158 node n;
159 list ipn_list; /* A list of struct iface_patt_node */
ed45f2e1 160
8edf2361 161 /* Protocol-specific data follow after this structure */
ed45f2e1
MM
162};
163
0aad2b92
OZ
164int iface_patt_match(struct iface_patt *ifp, struct iface *i, struct ifa *a);
165struct iface_patt *iface_patt_find(list *l, struct iface *i, struct ifa *a);
ed45f2e1
MM
166int iface_patts_equal(list *, list *, int (*)(struct iface_patt *, struct iface_patt *));
167
79b4e12e
OZ
168
169u32 if_choose_router_id(struct iface_patt *mask, u32 old_id);
170
58ef912c 171#endif