iface.h 5.3 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

14 15
extern list iface_list;

16
struct proto;
17
struct pool;
18

19 20 21 22 23 24 25 26 27 28 29 30
struct ifa {				/* Interface address */
  node n;
  struct iface *iface;			/* Interface this address belongs to */
  ip_addr ip;				/* IP address of this host */
  ip_addr prefix;			/* Network prefix */
  unsigned pxlen;			/* Prefix length */
  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 */
37 38
  list addrs;				/* Addresses assigned to this interface */
  struct ifa *addr;			/* Primary address */
39
  list neighbors;			/* All neighbors on this interface */
40 41
};

42
#define IF_UP 1				/* IF_ADMIN_UP and IP address known */
43
#define IF_MULTIACCESS 2
44 45
#define IF_BROADCAST 4
#define IF_MULTICAST 8
46
#define IF_SHUTDOWN 0x10		/* Interface disappeared */
47 48
#define IF_LOOPBACK 0x20
#define IF_IGNORE 0x40			/* Not to be used by routing protocols (loopbacks etc.) */
49 50
#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) */
51 52 53

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

58 59 60 61 62 63 64 65
/*
 * 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
66 67
 * 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.
68 69 70
 */


71 72
#define IF_JUST_CREATED 0x10000000	/* Send creation event as soon as possible */
#define IF_TMP_DOWN 0x20000000		/* Temporary shutdown due to interface reconfiguration */
Martin Mareš's avatar
Martin Mareš committed
73
#define IF_UPDATED 0x40000000		/* Touched in last scan */
74

75 76 77 78
/* Interface change events */

#define IF_CHANGE_UP 1
#define IF_CHANGE_DOWN 2
79 80
#define IF_CHANGE_MTU 4
#define IF_CHANGE_CREATE 8		/* Seen this interface for the first time */
81
#define IF_CHANGE_LINK 0x10
82
#define IF_CHANGE_TOO_MUCH 0x40000000	/* Used internally */
83 84 85 86

void if_init(void);
void if_dump(struct iface *);
void if_dump_all(void);
87
void ifa_dump(struct ifa *);
88 89
void if_show(void);
void if_show_summary(void);
90
struct iface *if_update(struct iface *);
91
void if_delete(struct iface *old);
92 93
struct ifa *ifa_update(struct ifa *);
void ifa_delete(struct ifa *);
94
void if_start_update(void);
95
void if_end_partial_update(struct iface *);
96 97
void if_end_update(void);
void if_flush_ifaces(struct proto *p);
98
void if_feed_baby(struct proto *);
99
struct iface *if_find_by_index(unsigned);
100
struct iface *if_find_by_name(char *);
101
struct iface *if_get_by_name(char *);
102
void ifa_recalc_all_primary_addresses(void);
103

104

105
/* The Neighbor Cache */
106 107 108

typedef struct neighbor {
  node n;				/* Node in global neighbor list */
109
  node if_n;				/* Node in per-interface neighbor list */
110
  ip_addr addr;				/* Address of the neighbor */
111
  struct ifa *ifa;			/* Ifa on related iface */
112
  struct iface *iface;			/* Interface it's connected to */
113 114
  struct proto *proto;			/* Protocol this belongs to */
  void *data;				/* Protocol-specific data */
115
  unsigned aux;				/* Protocol-specific data */
116
  unsigned flags;
117 118
  int scope;				/* Address scope, -1 for unreachable sticky neighbors,
					   SCOPE_HOST when it's our own address */
119 120 121
} neighbor;

#define NEF_STICKY 1
122
#define NEF_ONLINK 2
123
#define NEF_BIND 4			/* Used internally for neighbors bound to an iface */
124 125

neighbor *neigh_find(struct proto *, ip_addr *, unsigned flags);
126
neighbor *neigh_find2(struct proto *p, ip_addr *a, struct iface *ifa, unsigned flags);
127

128 129 130 131 132 133
static inline int neigh_connected_to(struct proto *p, ip_addr *a, struct iface *i)
{
  neighbor *n = neigh_find(p, a, 0);
  return n && n->iface == i;
}

134 135
void neigh_dump(neighbor *);
void neigh_dump_all(void);
136
void neigh_prune(void);
137 138
void neigh_if_up(struct iface *);
void neigh_if_down(struct iface *);
139
void neigh_if_link(struct iface *);
140
void neigh_ifa_update(struct ifa *);
141
void neigh_init(struct pool *);
142

143 144 145 146
/*
 *	Interface Pattern Lists
 */

147
struct iface_patt_node {
148
  node n;
149 150 151
  int positive;
  byte *pattern;
  ip_addr prefix;
152
  int pxlen;
153 154 155 156 157
};

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

159
  /* Protocol-specific data follow after this structure */
160 161
};

162 163
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);
164 165
int iface_patts_equal(list *, list *, int (*)(struct iface_patt *, struct iface_patt *));

166 167 168

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

169
#endif