Annotation of embedaddon/bird/nest/attrs.h, revision 1.1.1.1
1.1 misho 1: /*
2: * BIRD Internet Routing Daemon -- Attribute Operations
3: *
4: * (c) 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_ATTRS_H_
10: #define _BIRD_ATTRS_H_
11:
12: #include <stdint.h>
13:
14: /* a-path.c */
15:
16: #define AS_PATH_SET 1 /* Types of path segments */
17: #define AS_PATH_SEQUENCE 2
18: #define AS_PATH_CONFED_SEQUENCE 3
19: #define AS_PATH_CONFED_SET 4
20:
21: #define AS_PATH_MAXLEN 10000
22:
23: #define AS_TRANS 23456
24: /* AS_TRANS is used when we need to store 32bit ASN larger than 0xFFFF
25: * to 16bit slot (like in 16bit AS_PATH). See RFC 4893 for details
26: */
27:
28: struct f_tree;
29:
30: struct adata *as_path_prepend(struct linpool *pool, struct adata *olda, u32 as);
31: int as_path_convert_to_old(struct adata *path, byte *dst, int *new_used);
32: int as_path_convert_to_new(struct adata *path, byte *dst, int req_as);
33: void as_path_format(struct adata *path, byte *buf, uint size);
34: int as_path_getlen(struct adata *path);
35: int as_path_getlen_int(struct adata *path, int bs);
36: int as_path_get_first(struct adata *path, u32 *orig_as);
37: int as_path_get_last(struct adata *path, u32 *last_as);
38: u32 as_path_get_last_nonaggregated(struct adata *path);
39: int as_path_contains(struct adata *path, u32 as, int min);
40: int as_path_match_set(struct adata *path, struct f_tree *set);
41: struct adata *as_path_filter(struct linpool *pool, struct adata *path, struct f_tree *set, u32 key, int pos);
42:
43:
44: #define PM_ASN 0
45: #define PM_QUESTION 1
46: #define PM_ASTERISK 2
47: #define PM_ASN_EXPR 3
48: #define PM_ASN_RANGE 4
49:
50: struct f_path_mask {
51: struct f_path_mask *next;
52: int kind;
53: uintptr_t val;
54: uintptr_t val2;
55: };
56:
57: int as_path_match(struct adata *path, struct f_path_mask *mask);
58:
59: /* a-set.c */
60:
61:
62: /* Extended Community subtypes (kinds) */
63: #define EC_RT 0x0002
64: #define EC_RO 0x0003
65:
66: #define EC_GENERIC 0xFFFF
67:
68: /* Transitive bit (for first u32 half of EC) */
69: #define EC_TBIT 0x40000000
70:
71: #define ECOMM_LENGTH 8
72:
73: static inline int int_set_get_size(struct adata *list)
74: { return list->length / 4; }
75:
76: static inline int ec_set_get_size(struct adata *list)
77: { return list->length / 8; }
78:
79: static inline int lc_set_get_size(struct adata *list)
80: { return list->length / 12; }
81:
82: static inline u32 *int_set_get_data(struct adata *list)
83: { return (u32 *) list->data; }
84:
85: static inline u32 ec_hi(u64 ec) { return ec >> 32; }
86: static inline u32 ec_lo(u64 ec) { return ec; }
87: static inline u64 ec_get(const u32 *l, int i)
88: { return (((u64) l[i]) << 32) | l[i+1]; }
89:
90: /* RFC 4360 3.1. Two-Octet AS Specific Extended Community */
91: static inline u64 ec_as2(u64 kind, u64 key, u64 val)
92: { return ((kind | 0x0000) << 48) | (key << 32) | val; }
93:
94: /* RFC 5668 4-Octet AS Specific BGP Extended Community */
95: static inline u64 ec_as4(u64 kind, u64 key, u64 val)
96: { return ((kind | 0x0200) << 48) | (key << 16) | val; }
97:
98: /* RFC 4360 3.2. IPv4 Address Specific Extended Community */
99: static inline u64 ec_ip4(u64 kind, u64 key, u64 val)
100: { return ((kind | 0x0100) << 48) | (key << 16) | val; }
101:
102: static inline u64 ec_generic(u64 key, u64 val)
103: { return (key << 32) | val; }
104:
105: /* Large community value */
106: typedef struct lcomm {
107: u32 asn;
108: u32 ldp1;
109: u32 ldp2;
110: } lcomm;
111:
112: #define LCOMM_LENGTH 12
113:
114: static inline lcomm lc_get(const u32 *l, int i)
115: { return (lcomm) { l[i], l[i+1], l[i+2] }; }
116:
117: static inline void lc_put(u32 *l, lcomm v)
118: { l[0] = v.asn; l[1] = v.ldp1; l[2] = v.ldp2; }
119:
120: static inline int lc_match(const u32 *l, int i, lcomm v)
121: { return (l[i] == v.asn && l[i+1] == v.ldp1 && l[i+2] == v.ldp2); }
122:
123: static inline u32 *lc_copy(u32 *dst, const u32 *src)
124: { memcpy(dst, src, LCOMM_LENGTH); return dst + 3; }
125:
126:
127: int int_set_format(struct adata *set, int way, int from, byte *buf, uint size);
128: int ec_format(byte *buf, u64 ec);
129: int ec_set_format(struct adata *set, int from, byte *buf, uint size);
130: int lc_format(byte *buf, lcomm lc);
131: int lc_set_format(struct adata *set, int from, byte *buf, uint size);
132: int int_set_contains(struct adata *list, u32 val);
133: int ec_set_contains(struct adata *list, u64 val);
134: int lc_set_contains(struct adata *list, lcomm val);
135: struct adata *int_set_prepend(struct linpool *pool, struct adata *list, u32 val);
136: struct adata *int_set_add(struct linpool *pool, struct adata *list, u32 val);
137: struct adata *ec_set_add(struct linpool *pool, struct adata *list, u64 val);
138: struct adata *lc_set_add(struct linpool *pool, struct adata *list, lcomm val);
139: struct adata *int_set_del(struct linpool *pool, struct adata *list, u32 val);
140: struct adata *ec_set_del(struct linpool *pool, struct adata *list, u64 val);
141: struct adata *lc_set_del(struct linpool *pool, struct adata *list, lcomm val);
142: struct adata *int_set_union(struct linpool *pool, struct adata *l1, struct adata *l2);
143: struct adata *ec_set_union(struct linpool *pool, struct adata *l1, struct adata *l2);
144: struct adata *lc_set_union(struct linpool *pool, struct adata *l1, struct adata *l2);
145:
146:
147: #endif
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>