| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  *	BIRD Internet Routing Daemon -- Network Interfaces | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2000-06-01 16:17:29 +00:00
										 |  |  |  *	(c) 1998--2000 Martin Mares <mj@ucw.cz> | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00: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 14:39:34 +00:00
										 |  |  | #include "lib/lists.h"
 | 
					
						
							| 
									
										
										
										
											2016-11-09 16:36:34 +01:00
										 |  |  | #include "lib/ip.h"
 | 
					
						
							| 
									
										
										
										
											1998-04-23 14:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-05-26 21:42:05 +00:00
										 |  |  | extern list iface_list; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-10-17 11:05:18 +00:00
										 |  |  | struct proto; | 
					
						
							| 
									
										
										
										
											2000-03-01 14:51:47 +00:00
										 |  |  | struct pool; | 
					
						
							| 
									
										
										
										
											1998-10-17 11:05:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-05-06 21:38:11 +00:00
										 |  |  | struct ifa {				/* Interface address */ | 
					
						
							|  |  |  |   node n; | 
					
						
							|  |  |  |   struct iface *iface;			/* Interface this address belongs to */ | 
					
						
							| 
									
										
										
										
											2015-11-12 02:03:59 +01:00
										 |  |  |   net_addr prefix;			/* Network prefix */ | 
					
						
							| 
									
										
										
										
											1999-05-06 21:38:11 +00:00
										 |  |  |   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 */ | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-23 14:01:15 +00:00
										 |  |  | struct iface { | 
					
						
							|  |  |  |   node n; | 
					
						
							| 
									
										
										
										
											1998-05-26 21:42:05 +00:00
										 |  |  |   char name[16]; | 
					
						
							| 
									
										
										
										
											1998-04-23 14:01:15 +00:00
										 |  |  |   unsigned flags; | 
					
						
							| 
									
										
										
										
											1998-05-03 16:42:45 +00:00
										 |  |  |   unsigned mtu; | 
					
						
							| 
									
										
										
										
											1998-05-24 14:48:09 +00:00
										 |  |  |   unsigned index;			/* OS-dependent interface index */ | 
					
						
							| 
									
										
										
										
											2017-09-06 17:38:48 +02:00
										 |  |  |   unsigned master_index;		/* Interface index of master iface */ | 
					
						
							|  |  |  |   struct iface *master;			/* Master iface (e.g. for VRF) */ | 
					
						
							| 
									
										
										
										
											1999-05-06 21:38:11 +00:00
										 |  |  |   list addrs;				/* Addresses assigned to this interface */ | 
					
						
							| 
									
										
										
										
											2017-12-07 13:06:01 +01:00
										 |  |  |   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 */ | 
					
						
							| 
									
										
										
										
											2000-01-19 11:52:32 +00:00
										 |  |  |   list neighbors;			/* All neighbors on this interface */ | 
					
						
							| 
									
										
										
										
											1998-04-23 14:01:15 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-07 13:06:01 +01:00
										 |  |  | #define IF_UP 1				/* Currently just IF_ADMIN_UP */
 | 
					
						
							| 
									
										
										
										
											1998-04-23 14:01:15 +00:00
										 |  |  | #define IF_MULTIACCESS 2
 | 
					
						
							| 
									
										
										
										
											2000-02-29 23:19:52 +00:00
										 |  |  | #define IF_BROADCAST 4
 | 
					
						
							|  |  |  | #define IF_MULTICAST 8
 | 
					
						
							| 
									
										
										
										
											2010-11-11 10:03:02 +01:00
										 |  |  | #define IF_SHUTDOWN 0x10		/* Interface disappeared */
 | 
					
						
							| 
									
										
										
										
											2000-02-29 23:19:52 +00:00
										 |  |  | #define IF_LOOPBACK 0x20
 | 
					
						
							|  |  |  | #define IF_IGNORE 0x40			/* Not to be used by routing protocols (loopbacks etc.) */
 | 
					
						
							| 
									
										
										
										
											2010-11-19 18:03:27 +01: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-06 21:38:11 +00: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-28 22:46:18 +02:00
										 |  |  | #define IA_PEER 0x40000			/* A peer/ptp address */
 | 
					
						
							|  |  |  | #define IA_HOST 0x80000			/* A host/loopback address */
 | 
					
						
							| 
									
										
										
										
											1999-05-06 21:38:11 +00:00
										 |  |  | #define IA_FLAGS 0xff0000
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-28 22:46:18 +02: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 11:41:18 +02: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-28 22:46:18 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-28 16:43:17 +01:00
										 |  |  | #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 */
 | 
					
						
							| 
									
										
										
										
											2017-12-07 13:06:01 +01:00
										 |  |  | #define IF_NEEDS_RECALC	0x80000000	/* Preferred address recalculation is needed */
 | 
					
						
							| 
									
										
										
										
											2018-11-28 16:43:17 +01:00
										 |  |  | #define IF_LOST_ADDR4	0x01000000	/* Preferred address was deleted, notification needed */
 | 
					
						
							|  |  |  | #define IF_LOST_ADDR6	0x02000000
 | 
					
						
							|  |  |  | #define IF_LOST_LLV6	0x04000000
 | 
					
						
							| 
									
										
										
										
											2017-12-07 13:06:01 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-28 16:43:17 +01:00
										 |  |  | #define IA_UPDATED	IF_UPDATED	/* Address touched in last scan */
 | 
					
						
							| 
									
										
										
										
											1998-04-23 14:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-05-26 21:42:05 +00:00
										 |  |  | /* Interface change events */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define IF_CHANGE_UP 1
 | 
					
						
							|  |  |  | #define IF_CHANGE_DOWN 2
 | 
					
						
							| 
									
										
										
										
											1999-05-06 21:38:11 +00:00
										 |  |  | #define IF_CHANGE_MTU 4
 | 
					
						
							|  |  |  | #define IF_CHANGE_CREATE 8		/* Seen this interface for the first time */
 | 
					
						
							| 
									
										
										
										
											2010-11-11 10:03:02 +01:00
										 |  |  | #define IF_CHANGE_LINK 0x10
 | 
					
						
							| 
									
										
										
										
											2017-12-07 13:06:01 +01:00
										 |  |  | #define IF_CHANGE_ADDR4	0x100		/* Change of iface->addr4 */
 | 
					
						
							|  |  |  | #define IF_CHANGE_ADDR6	0x200		/* ... */
 | 
					
						
							|  |  |  | #define IF_CHANGE_LLV6 0x400
 | 
					
						
							|  |  |  | #define IF_CHANGE_SYSDEP 0x800
 | 
					
						
							| 
									
										
										
										
											1999-05-06 21:38:11 +00:00
										 |  |  | #define IF_CHANGE_TOO_MUCH 0x40000000	/* Used internally */
 | 
					
						
							| 
									
										
										
										
											1998-05-26 21:42:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-28 16:43:17 +01:00
										 |  |  | #define IF_CHANGE_UPDOWN (IF_CHANGE_UP | IF_CHANGE_DOWN)
 | 
					
						
							| 
									
										
										
										
											2017-12-07 13:06:01 +01:00
										 |  |  | #define IF_CHANGE_PREFERRED (IF_CHANGE_ADDR4 | IF_CHANGE_ADDR6 | IF_CHANGE_LLV6)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-05-26 21:42:05 +00:00
										 |  |  | void if_init(void); | 
					
						
							|  |  |  | void if_dump(struct iface *); | 
					
						
							|  |  |  | void if_dump_all(void); | 
					
						
							| 
									
										
										
										
											1999-05-06 21:38:11 +00:00
										 |  |  | void ifa_dump(struct ifa *); | 
					
						
							| 
									
										
										
										
											1999-11-25 15:35:30 +00:00
										 |  |  | void if_show(void); | 
					
						
							|  |  |  | void if_show_summary(void); | 
					
						
							| 
									
										
										
										
											1999-05-06 21:38:11 +00:00
										 |  |  | struct iface *if_update(struct iface *); | 
					
						
							| 
									
										
										
										
											2012-01-23 01:26:40 +01:00
										 |  |  | void if_delete(struct iface *old); | 
					
						
							| 
									
										
										
										
											1999-05-06 21:38:11 +00:00
										 |  |  | struct ifa *ifa_update(struct ifa *); | 
					
						
							|  |  |  | void ifa_delete(struct ifa *); | 
					
						
							| 
									
										
										
										
											1999-03-02 18:36:09 +00:00
										 |  |  | void if_start_update(void); | 
					
						
							| 
									
										
										
										
											1999-05-06 21:38:11 +00:00
										 |  |  | void if_end_partial_update(struct iface *); | 
					
						
							| 
									
										
										
										
											2010-02-27 16:00:07 +01:00
										 |  |  | void if_end_update(void); | 
					
						
							|  |  |  | void if_flush_ifaces(struct proto *p); | 
					
						
							| 
									
										
										
										
											1998-10-17 11:05:18 +00:00
										 |  |  | void if_feed_baby(struct proto *); | 
					
						
							| 
									
										
										
										
											1999-03-02 18:36:09 +00:00
										 |  |  | struct iface *if_find_by_index(unsigned); | 
					
						
							| 
									
										
										
										
											2020-04-08 22:25:15 +02:00
										 |  |  | struct iface *if_find_by_name(const char *); | 
					
						
							|  |  |  | struct iface *if_get_by_name(const char *); | 
					
						
							| 
									
										
										
										
											2017-12-07 13:06:01 +01:00
										 |  |  | void if_recalc_all_preferred_addresses(void); | 
					
						
							| 
									
										
										
										
											1998-05-26 21:42:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-27 12:56:23 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-06-01 16:17:29 +00:00
										 |  |  | /* The Neighbor Cache */ | 
					
						
							| 
									
										
										
										
											1998-06-01 21:41:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | typedef struct neighbor { | 
					
						
							| 
									
										
										
										
											2020-05-11 04:29:36 +02:00
										 |  |  |   node n;				/* Node in neighbor hash table chain */ | 
					
						
							| 
									
										
										
										
											2000-01-19 11:52:32 +00:00
										 |  |  |   node if_n;				/* Node in per-interface neighbor list */ | 
					
						
							| 
									
										
										
										
											1998-06-01 21:41:11 +00:00
										 |  |  |   ip_addr addr;				/* Address of the neighbor */ | 
					
						
							| 
									
										
										
										
											2013-12-02 11:54:32 +01:00
										 |  |  |   struct ifa *ifa;			/* Ifa on related iface */ | 
					
						
							| 
									
										
										
										
											1998-10-17 11:26:28 +00:00
										 |  |  |   struct iface *iface;			/* Interface it's connected to */ | 
					
						
							| 
									
										
										
										
											2018-06-27 16:51:53 +02:00
										 |  |  |   struct iface *ifreq;			/* Requested iface, NULL for any */ | 
					
						
							| 
									
										
										
										
											1998-06-01 21:41:11 +00:00
										 |  |  |   struct proto *proto;			/* Protocol this belongs to */ | 
					
						
							|  |  |  |   void *data;				/* Protocol-specific data */ | 
					
						
							| 
									
										
										
										
											2018-06-27 16:51:53 +02:00
										 |  |  |   uint aux;				/* Protocol-specific data */ | 
					
						
							|  |  |  |   u16 flags;				/* NEF_* flags */ | 
					
						
							|  |  |  |   s16 scope;				/* Address scope, -1 for unreachable neighbors,
 | 
					
						
							| 
									
										
										
										
											2012-01-01 12:02:20 +01:00
										 |  |  | 					   SCOPE_HOST when it's our own address */ | 
					
						
							| 
									
										
										
										
											1998-06-01 21:41:11 +00:00
										 |  |  | } neighbor; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-21 14:56:14 +01:00
										 |  |  | #define NEF_STICKY	1
 | 
					
						
							|  |  |  | #define NEF_ONLINK	2
 | 
					
						
							| 
									
										
										
										
											2018-06-27 16:51:53 +02:00
										 |  |  | #define NEF_IFACE	4		/* Entry for whole iface */
 | 
					
						
							| 
									
										
										
										
											1998-06-01 21:41:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 16:51:53 +02:00
										 |  |  | neighbor *neigh_find(struct proto *p, ip_addr a, struct iface *ifa, uint flags); | 
					
						
							| 
									
										
										
										
											2000-03-27 12:16:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-06-01 21:41:11 +00:00
										 |  |  | void neigh_dump(neighbor *); | 
					
						
							|  |  |  | void neigh_dump_all(void); | 
					
						
							| 
									
										
										
										
											1999-02-13 20:55:08 +00:00
										 |  |  | void neigh_prune(void); | 
					
						
							| 
									
										
										
										
											2000-03-01 14:51:47 +00:00
										 |  |  | void neigh_if_up(struct iface *); | 
					
						
							|  |  |  | void neigh_if_down(struct iface *); | 
					
						
							| 
									
										
										
										
											2010-11-11 12:24:27 +01:00
										 |  |  | void neigh_if_link(struct iface *); | 
					
						
							| 
									
										
										
										
											2020-05-11 04:29:36 +02:00
										 |  |  | void neigh_ifa_up(struct ifa *a); | 
					
						
							|  |  |  | void neigh_ifa_down(struct ifa *a); | 
					
						
							| 
									
										
										
										
											2000-03-01 14:51:47 +00:00
										 |  |  | void neigh_init(struct pool *); | 
					
						
							| 
									
										
										
										
											1998-06-01 21:41:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-11-29 22:01:03 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  *	Interface Pattern Lists | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-06 22:02:45 +02:00
										 |  |  | struct iface_patt_node { | 
					
						
							| 
									
										
										
										
											1998-11-29 22:01:03 +00:00
										 |  |  |   node n; | 
					
						
							| 
									
										
										
										
											2009-05-06 22:02:45 +02:00
										 |  |  |   int positive; | 
					
						
							| 
									
										
										
										
											2020-04-08 22:25:15 +02:00
										 |  |  |   const byte *pattern; | 
					
						
							| 
									
										
										
										
											2015-11-12 02:03:59 +01:00
										 |  |  |   net_addr prefix; | 
					
						
							| 
									
										
										
										
											2009-05-06 22:02:45 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct iface_patt { | 
					
						
							|  |  |  |   node n; | 
					
						
							|  |  |  |   list ipn_list;			/* A list of struct iface_patt_node */ | 
					
						
							| 
									
										
										
										
											1998-11-29 22:01:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-08-03 19:30:49 +00:00
										 |  |  |   /* Protocol-specific data follow after this structure */ | 
					
						
							| 
									
										
										
										
											1998-11-29 22:01:03 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-14 16:36:59 +01: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-29 22:01:03 +00:00
										 |  |  | int iface_patts_equal(list *, list *, int (*)(struct iface_patt *, struct iface_patt *)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-27 12:56:23 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | u32 if_choose_router_id(struct iface_patt *mask, u32 old_id); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-22 12:58:34 +00:00
										 |  |  | #endif
 |