iface.h 6 KB
Newer Older
1 2 3
/*
 *	BIRD Internet Routing Daemon -- Network Interfaces
 *
4
 *	(c) 1998--2000 Martin Mares <mj@ucw.cz>
5 6 7 8 9 10 11
 *
 *	Can be freely distributed and used under the terms of the GNU GPL.
 */

#ifndef _BIRD_IFACE_H_
#define _BIRD_IFACE_H_

12
#include "lib/lists.h"
13
#include "lib/ip.h"
14

15 16
extern list iface_list;

17
struct proto;
18
struct pool;
19

20 21 22
struct ifa {				/* Interface address */
  node n;
  struct iface *iface;			/* Interface this address belongs to */
23
  net_addr prefix;			/* Network prefix */
24 25 26 27 28 29 30
  ip_addr ip;				/* IP address of this host */
  ip_addr brd;				/* Broadcast address */
  ip_addr opposite;			/* Opposite end of a point-to-point link */
  unsigned scope;			/* Interface address scope */
  unsigned flags;			/* Analogous to iface->flags */
};

31 32
struct iface {
  node n;
33
  char name[16];
34
  unsigned flags;
35
  unsigned mtu;
36
  unsigned index;			/* OS-dependent interface index */
Ondřej Zajíček's avatar
Ondřej Zajíček committed
37 38
  unsigned master_index;		/* Interface index of master iface */
  struct iface *master;			/* Master iface (e.g. for VRF) */
39
  list addrs;				/* Addresses assigned to this interface */
40 41 42 43
  struct ifa *addr4;			/* Primary address for IPv4 */
  struct ifa *addr6;			/* Primary address for IPv6 */
  struct ifa *llv6;			/* Primary link-local address for IPv6 */
  ip4_addr sysdep;			/* Arbitrary IPv4 address for internal sysdep use */
44
  list neighbors;			/* All neighbors on this interface */
45 46
};

47
#define IF_UP 1				/* Currently just IF_ADMIN_UP */
48
#define IF_MULTIACCESS 2
49 50
#define IF_BROADCAST 4
#define IF_MULTICAST 8
51
#define IF_SHUTDOWN 0x10		/* Interface disappeared */
52 53
#define IF_LOOPBACK 0x20
#define IF_IGNORE 0x40			/* Not to be used by routing protocols (loopbacks etc.) */
54 55
#define IF_ADMIN_UP 0x80		/* Administrative up (e.g. IFF_UP in Linux) */
#define IF_LINK_UP 0x100		/* Link available (e.g. IFF_LOWER_UP in Linux) */
56 57 58

#define IA_PRIMARY 0x10000		/* This address is primary */
#define IA_SECONDARY 0x20000		/* This address has been reported as secondary by the kernel */
59 60
#define IA_PEER 0x40000			/* A peer/ptp address */
#define IA_HOST 0x80000			/* A host/loopback address */
61 62
#define IA_FLAGS 0xff0000

63 64 65 66 67 68 69 70
/*
 * There are three kinds of addresses in BIRD:
 *  - Standard (prefix-based) addresses, these may define ifa.opposite (for /30 or /31).
 *  - Peer/ptp addresses, without common prefix for ifa.ip and ifa.opposite.
 *    ifa.opposite is defined and ifa.prefix/pxlen == ifa.opposite/32 (for simplicity).
 *  - Host addresses, with ifa.prefix/pxlen == ifa.ip/32 (or /128).
 *    May be considered a special case of standard addresses.
 *
Ondřej Zajíček's avatar
Ondřej Zajíček committed
71 72
 * Peer addresses (AFAIK) do not exist in IPv6. Linux also supports generalized peer
 * addresses (with pxlen < 32 and ifa.ip outside prefix), we do not support that.
73 74 75
 */


76 77 78
#define IF_JUST_CREATED	0x10000000	/* Send creation event as soon as possible */
#define IF_TMP_DOWN	0x20000000	/* Temporary shutdown due to interface reconfiguration */
#define IF_UPDATED	0x40000000	/* Iface touched in last scan */
79
#define IF_NEEDS_RECALC	0x80000000	/* Preferred address recalculation is needed */
80 81 82
#define IF_LOST_ADDR4	0x01000000	/* Preferred address was deleted, notification needed */
#define IF_LOST_ADDR6	0x02000000
#define IF_LOST_LLV6	0x04000000
83

84
#define IA_UPDATED	IF_UPDATED	/* Address touched in last scan */
85

86 87 88 89
/* Interface change events */

#define IF_CHANGE_UP 1
#define IF_CHANGE_DOWN 2
90 91
#define IF_CHANGE_MTU 4
#define IF_CHANGE_CREATE 8		/* Seen this interface for the first time */
92
#define IF_CHANGE_LINK 0x10
93 94 95 96
#define IF_CHANGE_ADDR4	0x100		/* Change of iface->addr4 */
#define IF_CHANGE_ADDR6	0x200		/* ... */
#define IF_CHANGE_LLV6 0x400
#define IF_CHANGE_SYSDEP 0x800
97
#define IF_CHANGE_TOO_MUCH 0x40000000	/* Used internally */
98

99
#define IF_CHANGE_UPDOWN (IF_CHANGE_UP | IF_CHANGE_DOWN)
100 101
#define IF_CHANGE_PREFERRED (IF_CHANGE_ADDR4 | IF_CHANGE_ADDR6 | IF_CHANGE_LLV6)

102 103 104
void if_init(void);
void if_dump(struct iface *);
void if_dump_all(void);
105
void ifa_dump(struct ifa *);
106 107
void if_show(void);
void if_show_summary(void);
108
struct iface *if_update(struct iface *);
109
void if_delete(struct iface *old);
110 111
struct ifa *ifa_update(struct ifa *);
void ifa_delete(struct ifa *);
112
void if_start_update(void);
113
void if_end_partial_update(struct iface *);
114 115
void if_end_update(void);
void if_flush_ifaces(struct proto *p);
116
void if_feed_baby(struct proto *);
117
struct iface *if_find_by_index(unsigned);
118
struct iface *if_find_by_name(char *);
119
struct iface *if_get_by_name(char *);
120
void if_recalc_all_preferred_addresses(void);
121

122

123
/* The Neighbor Cache */
124 125 126

typedef struct neighbor {
  node n;				/* Node in global neighbor list */
127
  node if_n;				/* Node in per-interface neighbor list */
128
  ip_addr addr;				/* Address of the neighbor */
129
  struct ifa *ifa;			/* Ifa on related iface */
130
  struct iface *iface;			/* Interface it's connected to */
131
  struct iface *ifreq;			/* Requested iface, NULL for any */
132 133
  struct proto *proto;			/* Protocol this belongs to */
  void *data;				/* Protocol-specific data */
134 135 136
  uint aux;				/* Protocol-specific data */
  u16 flags;				/* NEF_* flags */
  s16 scope;				/* Address scope, -1 for unreachable neighbors,
137
					   SCOPE_HOST when it's our own address */
138 139
} neighbor;

140 141
#define NEF_STICKY	1
#define NEF_ONLINK	2
142
#define NEF_IFACE	4		/* Entry for whole iface */
143 144


145
neighbor *neigh_find(struct proto *p, ip_addr a, struct iface *ifa, uint flags);
146

147 148
void neigh_dump(neighbor *);
void neigh_dump_all(void);
149
void neigh_prune(void);
150 151
void neigh_if_up(struct iface *);
void neigh_if_down(struct iface *);
152
void neigh_if_link(struct iface *);
153
void neigh_ifa_update(struct ifa *);
154
void neigh_init(struct pool *);
155

156 157 158 159
/*
 *	Interface Pattern Lists
 */

160
struct iface_patt_node {
161
  node n;
162 163
  int positive;
  byte *pattern;
164
  net_addr prefix;
165 166 167 168 169
};

struct iface_patt {
  node n;
  list ipn_list;			/* A list of struct iface_patt_node */
170

171
  /* Protocol-specific data follow after this structure */
172 173
};

174 175
int iface_patt_match(struct iface_patt *ifp, struct iface *i, struct ifa *a);
struct iface_patt *iface_patt_find(list *l, struct iface *i, struct ifa *a);
176 177
int iface_patts_equal(list *, list *, int (*)(struct iface_patt *, struct iface_patt *));

178 179 180

u32 if_choose_router_id(struct iface_patt *mask, u32 old_id);

181
#endif