Annotation of embedaddon/bird2/nest/iface.h, revision 1.1
1.1 ! misho 1: /*
! 2: * BIRD Internet Routing Daemon -- Network Interfaces
! 3: *
! 4: * (c) 1998--2000 Martin Mares <mj@ucw.cz>
! 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:
! 12: #include "lib/lists.h"
! 13: #include "lib/ip.h"
! 14:
! 15: extern list iface_list;
! 16:
! 17: struct proto;
! 18: struct pool;
! 19:
! 20: struct ifa { /* Interface address */
! 21: node n;
! 22: struct iface *iface; /* Interface this address belongs to */
! 23: net_addr prefix; /* Network prefix */
! 24: ip_addr ip; /* IP address of this host */
! 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:
! 31: struct iface {
! 32: node n;
! 33: char name[16];
! 34: unsigned flags;
! 35: unsigned mtu;
! 36: unsigned index; /* OS-dependent interface index */
! 37: unsigned master_index; /* Interface index of master iface */
! 38: struct iface *master; /* Master iface (e.g. for VRF) */
! 39: list addrs; /* Addresses assigned to this interface */
! 40: struct ifa *addr4; /* Primary address for IPv4 */
! 41: struct ifa *addr6; /* Primary address for IPv6 */
! 42: struct ifa *llv6; /* Primary link-local address for IPv6 */
! 43: 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: #define IF_BROADCAST 4
! 50: #define IF_MULTICAST 8
! 51: #define IF_SHUTDOWN 0x10 /* Interface disappeared */
! 52: #define IF_LOOPBACK 0x20
! 53: #define IF_IGNORE 0x40 /* Not to be used by routing protocols (loopbacks etc.) */
! 54: #define IF_ADMIN_UP 0x80 /* Administrative up (e.g. IFF_UP in Linux) */
! 55: #define IF_LINK_UP 0x100 /* Link available (e.g. IFF_LOWER_UP in Linux) */
! 56:
! 57: #define IA_PRIMARY 0x10000 /* This address is primary */
! 58: #define IA_SECONDARY 0x20000 /* This address has been reported as secondary by the kernel */
! 59: #define IA_PEER 0x40000 /* A peer/ptp address */
! 60: #define IA_HOST 0x80000 /* A host/loopback address */
! 61: #define IA_FLAGS 0xff0000
! 62:
! 63: /*
! 64: * There are three kinds of addresses in BIRD:
! 65: * - Standard (prefix-based) addresses, these may define ifa.opposite (for /30 or /31).
! 66: * - Peer/ptp addresses, without common prefix for ifa.ip and ifa.opposite.
! 67: * ifa.opposite is defined and ifa.prefix/pxlen == ifa.opposite/32 (for simplicity).
! 68: * - Host addresses, with ifa.prefix/pxlen == ifa.ip/32 (or /128).
! 69: * May be considered a special case of standard addresses.
! 70: *
! 71: * Peer addresses (AFAIK) do not exist in IPv6. Linux also supports generalized peer
! 72: * addresses (with pxlen < 32 and ifa.ip outside prefix), we do not support that.
! 73: */
! 74:
! 75:
! 76: #define IF_JUST_CREATED 0x10000000 /* Send creation event as soon as possible */
! 77: #define IF_TMP_DOWN 0x20000000 /* Temporary shutdown due to interface reconfiguration */
! 78: #define IF_UPDATED 0x40000000 /* Iface touched in last scan */
! 79: #define IF_NEEDS_RECALC 0x80000000 /* Preferred address recalculation is needed */
! 80: #define IF_LOST_ADDR4 0x01000000 /* Preferred address was deleted, notification needed */
! 81: #define IF_LOST_ADDR6 0x02000000
! 82: #define IF_LOST_LLV6 0x04000000
! 83:
! 84: #define IA_UPDATED IF_UPDATED /* Address touched in last scan */
! 85:
! 86: /* Interface change events */
! 87:
! 88: #define IF_CHANGE_UP 1
! 89: #define IF_CHANGE_DOWN 2
! 90: #define IF_CHANGE_MTU 4
! 91: #define IF_CHANGE_CREATE 8 /* Seen this interface for the first time */
! 92: #define IF_CHANGE_LINK 0x10
! 93: #define IF_CHANGE_ADDR4 0x100 /* Change of iface->addr4 */
! 94: #define IF_CHANGE_ADDR6 0x200 /* ... */
! 95: #define IF_CHANGE_LLV6 0x400
! 96: #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: #define IF_CHANGE_PREFERRED (IF_CHANGE_ADDR4 | IF_CHANGE_ADDR6 | IF_CHANGE_LLV6)
! 101:
! 102: void if_init(void);
! 103: void if_dump(struct iface *);
! 104: void if_dump_all(void);
! 105: void ifa_dump(struct ifa *);
! 106: void if_show(void);
! 107: void if_show_summary(void);
! 108: struct iface *if_update(struct iface *);
! 109: void if_delete(struct iface *old);
! 110: struct ifa *ifa_update(struct ifa *);
! 111: void ifa_delete(struct ifa *);
! 112: void if_start_update(void);
! 113: void if_end_partial_update(struct iface *);
! 114: void if_end_update(void);
! 115: 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: typedef struct neighbor {
! 126: 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: struct proto *proto; /* Protocol this belongs to */
! 133: void *data; /* Protocol-specific data */
! 134: uint aux; /* Protocol-specific data */
! 135: u16 flags; /* NEF_* flags */
! 136: s16 scope; /* Address scope, -1 for unreachable neighbors,
! 137: SCOPE_HOST when it's our own address */
! 138: } neighbor;
! 139:
! 140: #define NEF_STICKY 1
! 141: #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: void neigh_dump(neighbor *);
! 148: void neigh_dump_all(void);
! 149: void neigh_prune(void);
! 150: void neigh_if_up(struct iface *);
! 151: 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: * Interface Pattern Lists
! 158: */
! 159:
! 160: struct iface_patt_node {
! 161: node n;
! 162: int positive;
! 163: byte *pattern;
! 164: net_addr prefix;
! 165: };
! 166:
! 167: struct iface_patt {
! 168: node n;
! 169: list ipn_list; /* A list of struct iface_patt_node */
! 170:
! 171: /* Protocol-specific data follow after this structure */
! 172: };
! 173:
! 174: int iface_patt_match(struct iface_patt *ifp, struct iface *i, struct ifa *a);
! 175: struct iface_patt *iface_patt_find(list *l, struct iface *i, struct ifa *a);
! 176: int iface_patts_equal(list *, list *, int (*)(struct iface_patt *, struct iface_patt *));
! 177:
! 178:
! 179: u32 if_choose_router_id(struct iface_patt *mask, u32 old_id);
! 180:
! 181: #endif
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>