1998-04-22 20:58:34 +08:00
|
|
|
/*
|
|
|
|
* BIRD Internet Routing Daemon -- Network Interfaces
|
|
|
|
*
|
2000-06-02 00:17:29 +08:00
|
|
|
* (c) 1998--2000 Martin Mares <mj@ucw.cz>
|
1998-04-22 20:58:34 +08:00
|
|
|
*
|
|
|
|
* Can be freely distributed and used under the terms of the GNU GPL.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _BIRD_IFACE_H_
|
|
|
|
#define _BIRD_IFACE_H_
|
|
|
|
|
1998-04-28 22:39:34 +08:00
|
|
|
#include "lib/lists.h"
|
1998-04-23 22:01:15 +08:00
|
|
|
|
1998-05-27 05:42:05 +08:00
|
|
|
extern list iface_list;
|
|
|
|
|
1998-10-17 19:05:18 +08:00
|
|
|
struct proto;
|
2000-03-01 22:51:47 +08:00
|
|
|
struct pool;
|
1998-10-17 19:05:18 +08:00
|
|
|
|
1999-05-07 05:38:11 +08:00
|
|
|
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 */
|
|
|
|
};
|
|
|
|
|
1998-04-23 22:01:15 +08:00
|
|
|
struct iface {
|
|
|
|
node n;
|
1998-05-27 05:42:05 +08:00
|
|
|
char name[16];
|
1998-04-23 22:01:15 +08:00
|
|
|
unsigned flags;
|
1998-05-04 00:42:45 +08:00
|
|
|
unsigned mtu;
|
1998-05-24 22:48:09 +08:00
|
|
|
unsigned index; /* OS-dependent interface index */
|
1999-05-07 05:38:11 +08:00
|
|
|
list addrs; /* Addresses assigned to this interface */
|
|
|
|
struct ifa *addr; /* Primary address */
|
2000-01-19 19:52:32 +08:00
|
|
|
list neighbors; /* All neighbors on this interface */
|
1998-04-23 22:01:15 +08:00
|
|
|
};
|
|
|
|
|
2010-11-11 17:03:02 +08:00
|
|
|
#define IF_UP 1 /* IF_ADMIN_UP and IP address known */
|
1998-04-23 22:01:15 +08:00
|
|
|
#define IF_MULTIACCESS 2
|
2000-03-01 07:19:52 +08:00
|
|
|
#define IF_BROADCAST 4
|
|
|
|
#define IF_MULTICAST 8
|
2010-11-11 17:03:02 +08:00
|
|
|
#define IF_SHUTDOWN 0x10 /* Interface disappeared */
|
2000-03-01 07:19:52 +08:00
|
|
|
#define IF_LOOPBACK 0x20
|
|
|
|
#define IF_IGNORE 0x40 /* Not to be used by routing protocols (loopbacks etc.) */
|
2010-11-20 01:03:27 +08:00
|
|
|
#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) */
|
1999-05-07 05:38:11 +08:00
|
|
|
|
|
|
|
#define IA_PRIMARY 0x10000 /* This address is primary */
|
|
|
|
#define IA_SECONDARY 0x20000 /* This address has been reported as secondary by the kernel */
|
2011-03-29 04:46:18 +08:00
|
|
|
#define IA_PEER 0x40000 /* A peer/ptp address */
|
|
|
|
#define IA_HOST 0x80000 /* A host/loopback address */
|
1999-05-07 05:38:11 +08:00
|
|
|
#define IA_FLAGS 0xff0000
|
|
|
|
|
2011-03-29 04:46:18 +08:00
|
|
|
/*
|
|
|
|
* 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.
|
|
|
|
*
|
2011-04-05 17:41:18 +08:00
|
|
|
* 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.
|
2011-03-29 04:46:18 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
1999-05-07 05:38:11 +08:00
|
|
|
#define IF_JUST_CREATED 0x10000000 /* Send creation event as soon as possible */
|
|
|
|
#define IF_TMP_DOWN 0x20000000 /* Temporary shutdown due to interface reconfiguration */
|
1999-03-03 01:28:06 +08:00
|
|
|
#define IF_UPDATED 0x40000000 /* Touched in last scan */
|
1998-04-23 22:01:15 +08:00
|
|
|
|
1998-05-27 05:42:05 +08:00
|
|
|
/* Interface change events */
|
|
|
|
|
|
|
|
#define IF_CHANGE_UP 1
|
|
|
|
#define IF_CHANGE_DOWN 2
|
1999-05-07 05:38:11 +08:00
|
|
|
#define IF_CHANGE_MTU 4
|
|
|
|
#define IF_CHANGE_CREATE 8 /* Seen this interface for the first time */
|
2010-11-11 17:03:02 +08:00
|
|
|
#define IF_CHANGE_LINK 0x10
|
1999-05-07 05:38:11 +08:00
|
|
|
#define IF_CHANGE_TOO_MUCH 0x40000000 /* Used internally */
|
1998-05-27 05:42:05 +08:00
|
|
|
|
|
|
|
void if_init(void);
|
|
|
|
void if_dump(struct iface *);
|
|
|
|
void if_dump_all(void);
|
1999-05-07 05:38:11 +08:00
|
|
|
void ifa_dump(struct ifa *);
|
1999-11-25 23:35:30 +08:00
|
|
|
void if_show(void);
|
|
|
|
void if_show_summary(void);
|
1999-05-07 05:38:11 +08:00
|
|
|
struct iface *if_update(struct iface *);
|
2012-01-23 08:26:40 +08:00
|
|
|
void if_delete(struct iface *old);
|
1999-05-07 05:38:11 +08:00
|
|
|
struct ifa *ifa_update(struct ifa *);
|
|
|
|
void ifa_delete(struct ifa *);
|
1999-03-03 02:36:09 +08:00
|
|
|
void if_start_update(void);
|
1999-05-07 05:38:11 +08:00
|
|
|
void if_end_partial_update(struct iface *);
|
2010-02-27 23:00:07 +08:00
|
|
|
void if_end_update(void);
|
|
|
|
void if_flush_ifaces(struct proto *p);
|
1998-10-17 19:05:18 +08:00
|
|
|
void if_feed_baby(struct proto *);
|
1999-03-03 02:36:09 +08:00
|
|
|
struct iface *if_find_by_index(unsigned);
|
1999-05-07 05:38:11 +08:00
|
|
|
struct iface *if_find_by_name(char *);
|
2012-01-01 19:02:20 +08:00
|
|
|
struct iface *if_get_by_name(char *);
|
2009-05-30 04:49:30 +08:00
|
|
|
void ifa_recalc_all_primary_addresses(void);
|
1998-05-27 05:42:05 +08:00
|
|
|
|
2000-06-02 00:17:29 +08:00
|
|
|
/* The Neighbor Cache */
|
1998-06-02 05:41:11 +08:00
|
|
|
|
|
|
|
typedef struct neighbor {
|
|
|
|
node n; /* Node in global neighbor list */
|
2000-01-19 19:52:32 +08:00
|
|
|
node if_n; /* Node in per-interface neighbor list */
|
1998-06-02 05:41:11 +08:00
|
|
|
ip_addr addr; /* Address of the neighbor */
|
1998-10-17 19:26:28 +08:00
|
|
|
struct iface *iface; /* Interface it's connected to */
|
1998-06-02 05:41:11 +08:00
|
|
|
struct proto *proto; /* Protocol this belongs to */
|
|
|
|
void *data; /* Protocol-specific data */
|
1999-12-01 19:59:24 +08:00
|
|
|
unsigned aux; /* Protocol-specific data */
|
1998-06-02 05:41:11 +08:00
|
|
|
unsigned flags;
|
2012-01-01 19:02:20 +08:00
|
|
|
int scope; /* Address scope, -1 for unreachable sticky neighbors,
|
|
|
|
SCOPE_HOST when it's our own address */
|
1998-06-02 05:41:11 +08:00
|
|
|
} neighbor;
|
|
|
|
|
|
|
|
#define NEF_STICKY 1
|
2010-02-26 17:55:58 +08:00
|
|
|
#define NEF_ONLINK 2
|
2012-01-01 19:02:20 +08:00
|
|
|
#define NEF_BIND 4 /* Used internally for neighbors bound to an iface */
|
1998-06-02 05:41:11 +08:00
|
|
|
|
|
|
|
neighbor *neigh_find(struct proto *, ip_addr *, unsigned flags);
|
2009-09-08 19:45:02 +08:00
|
|
|
neighbor *neigh_find2(struct proto *p, ip_addr *a, struct iface *ifa, unsigned flags);
|
1998-06-02 05:41:11 +08:00
|
|
|
|
2000-03-27 20:16:37 +08:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
1998-06-02 05:41:11 +08:00
|
|
|
void neigh_dump(neighbor *);
|
|
|
|
void neigh_dump_all(void);
|
1999-02-14 04:55:08 +08:00
|
|
|
void neigh_prune(void);
|
2000-03-01 22:51:47 +08:00
|
|
|
void neigh_if_up(struct iface *);
|
|
|
|
void neigh_if_down(struct iface *);
|
2010-11-11 19:24:27 +08:00
|
|
|
void neigh_if_link(struct iface *);
|
2011-12-12 07:24:15 +08:00
|
|
|
void neigh_ifa_update(struct ifa *);
|
2000-03-01 22:51:47 +08:00
|
|
|
void neigh_init(struct pool *);
|
1998-06-02 05:41:11 +08:00
|
|
|
|
1998-11-30 06:01:03 +08:00
|
|
|
/*
|
|
|
|
* Interface Pattern Lists
|
|
|
|
*/
|
|
|
|
|
2009-05-07 04:02:45 +08:00
|
|
|
struct iface_patt_node {
|
1998-11-30 06:01:03 +08:00
|
|
|
node n;
|
2009-05-07 04:02:45 +08:00
|
|
|
int positive;
|
|
|
|
byte *pattern;
|
|
|
|
ip_addr prefix;
|
1999-08-04 03:30:49 +08:00
|
|
|
int pxlen;
|
2009-05-07 04:02:45 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct iface_patt {
|
|
|
|
node n;
|
|
|
|
list ipn_list; /* A list of struct iface_patt_node */
|
1998-11-30 06:01:03 +08:00
|
|
|
|
1999-08-04 03:30:49 +08:00
|
|
|
/* Protocol-specific data follow after this structure */
|
1998-11-30 06:01:03 +08:00
|
|
|
};
|
|
|
|
|
2010-03-14 23:36:59 +08:00
|
|
|
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);
|
1998-11-30 06:01:03 +08:00
|
|
|
int iface_patts_equal(list *, list *, int (*)(struct iface_patt *, struct iface_patt *));
|
|
|
|
|
1998-04-22 20:58:34 +08:00
|
|
|
#endif
|