]> git.proxmox.com Git - mirror_frr.git/blame - lib/zebra.h
Merge pull request #768 from qlyoung/fix-gitignore2
[mirror_frr.git] / lib / zebra.h
CommitLineData
718e3744 1/* Zebra common header.
896014f4
DL
2 * Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002 Kunihiro Ishiguro
3 *
4 * This file is part of GNU Zebra.
5 *
6 * GNU Zebra is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation; either version 2, or (at your option) any
9 * later version.
10 *
11 * GNU Zebra is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License along
17 * with this program; see the file COPYING; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
19 */
718e3744 20
21#ifndef _ZEBRA_H
22#define _ZEBRA_H
23
24#ifdef HAVE_CONFIG_H
25#include "config.h"
26#endif /* HAVE_CONFIG_H */
27
28#ifdef SUNOS_5
29#define _XPG4_2
9bcdb638 30typedef unsigned int u_int32_t;
31typedef unsigned short u_int16_t;
32typedef unsigned char u_int8_t;
718e3744 33#endif /* SUNOS_5 */
34
35#include <unistd.h>
36#include <stdio.h>
37#include <stdlib.h>
c423d413 38#include <stddef.h>
718e3744 39#include <ctype.h>
40#include <errno.h>
41#include <fcntl.h>
42#include <signal.h>
43#include <string.h>
edd7c245 44#include <pwd.h>
45#include <grp.h>
718e3744 46#ifdef HAVE_STROPTS_H
47#include <stropts.h>
48#endif /* HAVE_STROPTS_H */
718e3744 49#include <sys/select.h>
718e3744 50#include <sys/stat.h>
718e3744 51#include <sys/types.h>
52#include <sys/param.h>
53#ifdef HAVE_SYS_SYSCTL_H
0dc0b708
AS
54#ifdef GNU_LINUX
55#include <linux/types.h>
56#endif
718e3744 57#include <sys/sysctl.h>
58#endif /* HAVE_SYS_SYSCTL_H */
59#include <sys/ioctl.h>
60#ifdef HAVE_SYS_CONF_H
61#include <sys/conf.h>
62#endif /* HAVE_SYS_CONF_H */
63#ifdef HAVE_SYS_KSYM_H
64#include <sys/ksym.h>
65#endif /* HAVE_SYS_KSYM_H */
66#include <syslog.h>
24f5e2fc
DL
67#include <sys/time.h>
68#include <time.h>
718e3744 69#include <sys/uio.h>
70#include <sys/utsname.h>
718e3744 71#include <sys/resource.h>
a58c25b6 72#include <limits.h>
35cfc90c 73#include <inttypes.h>
63a13864 74#include <stdbool.h>
718e3744 75
76/* machine dependent includes */
77#ifdef SUNOS_5
718e3744 78#include <strings.h>
79#endif /* SUNOS_5 */
80
81/* machine dependent includes */
82#ifdef HAVE_LINUX_VERSION_H
83#include <linux/version.h>
84#endif /* HAVE_LINUX_VERSION_H */
85
ba965c6c 86#ifdef HAVE_ASM_TYPES_H
87#include <asm/types.h>
88#endif /* HAVE_ASM_TYPES_H */
89
718e3744 90/* misc include group */
91#include <stdarg.h>
4cf0d0df 92#if !(defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L)
93/* Not C99; do we need to define va_copy? */
e22f5516 94#ifndef va_copy
95#ifdef __va_copy
4cf0d0df 96#define va_copy(DST,SRC) __va_copy(DST,SRC)
e22f5516 97#else
98/* Now we are desperate; this should work on many typical platforms.
99 But this is slightly dangerous, because the standard does not require
100 va_copy to be a macro. */
101#define va_copy(DST,SRC) memcpy(&(DST), &(SRC), sizeof(va_list))
102#warning "Not C99 and no va_copy macro available, falling back to memcpy"
103#endif /* __va_copy */
104#endif /* !va_copy */
4cf0d0df 105#endif /* !C99 */
db8eaac6 106
718e3744 107
ba3a0bc5 108#ifdef HAVE_LCAPS
109#include <sys/capability.h>
110#include <sys/prctl.h>
111#endif /* HAVE_LCAPS */
112
ceacedba 113#ifdef HAVE_SOLARIS_CAPABILITIES
114#include <priv.h>
115#endif /* HAVE_SOLARIS_CAPABILITIES */
116
718e3744 117/* network include group */
118
119#include <sys/socket.h>
120
121#ifdef HAVE_SYS_SOCKIO_H
122#include <sys/sockio.h>
123#endif /* HAVE_SYS_SOCKIO_H */
124
ea057677
HT
125#ifdef __APPLE__
126#define __APPLE_USE_RFC_3542
127#endif
128
6021c8d3
DS
129#include "lib/openbsd-tree.h"
130
718e3744 131#include <netinet/in.h>
718e3744 132#include <netinet/in_systm.h>
133#include <netinet/ip.h>
134#include <netinet/tcp.h>
135
136#ifdef HAVE_NET_NETOPT_H
137#include <net/netopt.h>
138#endif /* HAVE_NET_NETOPT_H */
139
140#include <net/if.h>
141
142#ifdef HAVE_NET_IF_DL_H
143#include <net/if_dl.h>
144#endif /* HAVE_NET_IF_DL_H */
145
146#ifdef HAVE_NET_IF_VAR_H
147#include <net/if_var.h>
148#endif /* HAVE_NET_IF_VAR_H */
149
150#include <net/route.h>
151
152#ifdef HAVE_NETLINK
153#include <linux/netlink.h>
154#include <linux/rtnetlink.h>
768a27ea 155#include <linux/filter.h>
718e3744 156#else
157#define RT_TABLE_MAIN 0
158#endif /* HAVE_NETLINK */
159
718e3744 160#include <netdb.h>
718e3744 161#include <arpa/inet.h>
718e3744 162
163#ifdef HAVE_INET_ND_H
164#include <inet/nd.h>
165#endif /* HAVE_INET_ND_H */
166
167#ifdef HAVE_NETINET_IN_VAR_H
168#include <netinet/in_var.h>
169#endif /* HAVE_NETINET_IN_VAR_H */
170
726f9b2b 171#ifdef HAVE_NETINET6_IN6_VAR_H
172#include <netinet6/in6_var.h>
173#endif /* HAVE_NETINET6_IN6_VAR_H */
174
718e3744 175#ifdef HAVE_NETINET_IN6_VAR_H
176#include <netinet/in6_var.h>
177#endif /* HAVE_NETINET_IN6_VAR_H */
178
179#ifdef HAVE_NETINET6_IN_H
180#include <netinet6/in.h>
181#endif /* HAVE_NETINET6_IN_H */
182
183
184#ifdef HAVE_NETINET6_IP6_H
185#include <netinet6/ip6.h>
186#endif /* HAVE_NETINET6_IP6_H */
187
718e3744 188#include <netinet/icmp6.h>
718e3744 189
190#ifdef HAVE_NETINET6_ND6_H
191#include <netinet6/nd6.h>
192#endif /* HAVE_NETINET6_ND6_H */
193
35cfc90c
PJ
194/* Some systems do not define UINT32_MAX, etc.. from inttypes.h
195 * e.g. this makes life easier for FBSD 4.11 users.
196 */
197#ifndef INT8_MAX
198#define INT8_MAX (127)
199#endif
200#ifndef INT16_MAX
201#define INT16_MAX (32767)
202#endif
203#ifndef INT32_MAX
204#define INT32_MAX (2147483647)
205#endif
206#ifndef UINT8_MAX
207#define UINT8_MAX (255U)
208#endif
209#ifndef UINT16_MAX
210#define UINT16_MAX (65535U)
211#endif
3b424979 212#ifndef UINT32_MAX
35cfc90c
PJ
213#define UINT32_MAX (4294967295U)
214#endif
3b424979 215
fb2d1502 216#ifdef HAVE_GLIBC_BACKTRACE
217#include <execinfo.h>
218#endif /* HAVE_GLIBC_BACKTRACE */
219
db8eaac6 220/* Local includes: */
221#if !(defined(__GNUC__) || defined(VTYSH_EXTRACT_PL))
222#define __attribute__(x)
223#endif /* !__GNUC__ || VTYSH_EXTRACT_PL */
224
225#include "zassert.h"
226
c5d9d3bb
DL
227#ifndef HAVE_STRLCAT
228size_t strlcat (char *__restrict dest, const char *__restrict src, size_t size);
229#endif
230#ifndef HAVE_STRLCPY
231size_t strlcpy (char *__restrict dest, const char *__restrict src, size_t size);
232#endif
db8eaac6 233
b99760ab 234#ifdef HAVE_BROKEN_CMSG_FIRSTHDR
235/* This bug is present in Solaris 8 and pre-patch Solaris 9 <sys/socket.h>;
236 please refer to http://bugzilla.quagga.net/show_bug.cgi?id=142 */
237
238/* Check that msg_controllen is large enough. */
239#define ZCMSG_FIRSTHDR(mhdr) \
240 (((size_t)((mhdr)->msg_controllen) >= sizeof(struct cmsghdr)) ? \
241 CMSG_FIRSTHDR(mhdr) : (struct cmsghdr *)NULL)
242
243#warning "CMSG_FIRSTHDR is broken on this platform, using a workaround"
244
245#else /* HAVE_BROKEN_CMSG_FIRSTHDR */
246#define ZCMSG_FIRSTHDR(M) CMSG_FIRSTHDR(M)
247#endif /* HAVE_BROKEN_CMSG_FIRSTHDR */
248
249
250
02ff83c5 251/*
69e1325f 252 * RFC 3542 defines several macros for using struct cmsghdr.
253 * Here, we define those that are not present
254 */
255
256/*
257 * Internal defines, for use only in this file.
258 * These are likely wrong on other than ILP32 machines, so warn.
02ff83c5 259 */
260#ifndef _CMSG_DATA_ALIGN
261#define _CMSG_DATA_ALIGN(n) (((n) + 3) & ~3)
262#endif /* _CMSG_DATA_ALIGN */
263
264#ifndef _CMSG_HDR_ALIGN
265#define _CMSG_HDR_ALIGN(n) (((n) + 3) & ~3)
266#endif /* _CMSG_HDR_ALIGN */
267
69e1325f 268/*
269 * CMSG_SPACE and CMSG_LEN are required in RFC3542, but were new in that
270 * version.
271 */
02ff83c5 272#ifndef CMSG_SPACE
273#define CMSG_SPACE(l) (_CMSG_DATA_ALIGN(sizeof(struct cmsghdr)) + \
274 _CMSG_HDR_ALIGN(l))
69e1325f 275#warning "assuming 4-byte alignment for CMSG_SPACE"
02ff83c5 276#endif /* CMSG_SPACE */
277
278
279#ifndef CMSG_LEN
280#define CMSG_LEN(l) (_CMSG_DATA_ALIGN(sizeof(struct cmsghdr)) + (l))
69e1325f 281#warning "assuming 4-byte alignment for CMSG_LEN"
02ff83c5 282#endif /* CMSG_LEN */
283
69e1325f 284
718e3744 285/* The definition of struct in_pktinfo is missing in old version of
286 GLIBC 2.1 (Redhat 6.1). */
6f0e3f6e 287#if defined (GNU_LINUX) && ! defined (HAVE_STRUCT_IN_PKTINFO)
718e3744 288struct in_pktinfo
289{
290 int ipi_ifindex;
291 struct in_addr ipi_spec_dst;
292 struct in_addr ipi_addr;
293};
294#endif
295
9172ee0e 296/*
297 * IP_HDRINCL / struct ip byte order
298 *
299 * Linux: network byte order
300 * *BSD: network, except for length and offset. (cf Stevens)
301 * SunOS: nominally as per BSD. but bug: network order on LE.
302 * OpenBSD: network byte order, apart from older versions which are as per
303 * *BSD
304 */
618969ea
OCL
305#if defined(__NetBSD__) \
306 || (defined(__FreeBSD__) && (__FreeBSD_version < 1100030)) \
9172ee0e 307 || (defined(__OpenBSD__) && (OpenBSD < 200311)) \
3f0bfc9e 308 || (defined(__APPLE__)) \
9172ee0e 309 || (defined(SUNOS_5) && defined(WORDS_BIGENDIAN))
310#define HAVE_IP_HDRINCL_BSD_ORDER
311#endif
312
34204aac 313/* Define BYTE_ORDER, if not defined. Useful for compiler conditional
314 * code, rather than preprocessor conditional.
315 * Not all the world has this BSD define.
316 */
317#ifndef BYTE_ORDER
318#define BIG_ENDIAN 4321 /* least-significant byte first (vax, pc) */
319#define LITTLE_ENDIAN 1234 /* most-significant byte first (IBM, net) */
320#define PDP_ENDIAN 3412 /* LSB first in word, MSW first in long (pdp) */
321
322#if defined(WORDS_BIGENDIAN)
323#define BYTE_ORDER BIG_ENDIAN
324#else /* !WORDS_BIGENDIAN */
325#define BYTE_ORDER LITTLE_ENDIAN
326#endif /* WORDS_BIGENDIAN */
327
328#endif /* ndef BYTE_ORDER */
329
efba6ce9 330/* MAX / MIN are not commonly defined, but useful */
6b143a68
DL
331/* note: glibc sys/param.h has #define MIN(a,b) (((a)<(b))?(a):(b)) */
332#ifdef MAX
333#undef MAX
334#endif
8a0bebfc
DL
335#define MAX(a, b) \
336 ({ typeof (a) _a = (a); \
337 typeof (b) _b = (b); \
338 _a > _b ? _a : _b; })
6b143a68
DL
339#ifdef MIN
340#undef MIN
8a0bebfc 341#endif
8a0bebfc
DL
342#define MIN(a, b) \
343 ({ typeof (a) _a = (a); \
344 typeof (b) _b = (b); \
345 _a < _b ? _a : _b; })
efba6ce9 346
0915bb0c
AS
347#define ZEBRA_NUM_OF(x) (sizeof (x) / sizeof (x[0]))
348
718e3744 349/* For old definition. */
350#ifndef IN6_ARE_ADDR_EQUAL
351#define IN6_ARE_ADDR_EQUAL IN6_IS_ADDR_EQUAL
352#endif /* IN6_ARE_ADDR_EQUAL */
353
8cc4198f 354/* default zebra TCP port for zclient */
355#define ZEBRA_PORT 2600
356
c1b9800a 357/* Marker value used in new Zserv, in the byte location corresponding
358 * the command value in the old zserv header. To allow old and new
359 * Zserv headers to be distinguished from each other.
360 */
80e71dcd 361#define ZEBRA_HEADER_MARKER 254
c1b9800a 362
e0ca5fde
DL
363/* Zebra route's types are defined in route_types.h */
364#include "route_types.h"
718e3744 365
d6d672aa
PJ
366/* Note: whenever a new route-type or zserv-command is added the
367 * corresponding {command,route}_types[] table in lib/log.c MUST be
368 * updated! */
f52d13cb 369
370/* Map a route type to a string. For example, ZEBRA_ROUTE_RIPNG -> "ripng". */
b6026073 371extern const char *zebra_route_string(unsigned int route_type);
f52d13cb 372/* Map a route type to a char. For example, ZEBRA_ROUTE_RIPNG -> 'R'. */
b6026073 373extern char zebra_route_char(unsigned int route_type);
d6d672aa
PJ
374/* Map a zserv command type to the same string,
375 * e.g. ZEBRA_INTERFACE_ADD -> "ZEBRA_INTERFACE_ADD" */
7514fb77
PJ
376/* Map a protocol name to its number. e.g. ZEBRA_ROUTE_BGP->9*/
377extern int proto_name2num(const char *s);
e0ca5fde
DL
378/* Map redistribute X argument to protocol number.
379 * unlike proto_name2num, this accepts shorthands and takes
380 * an AFI value to restrict input */
381extern int proto_redistnum(int afi, const char *s);
7514fb77 382
d6d672aa 383extern const char *zserv_command_string (unsigned int command);
f52d13cb 384
bf31fc81
DL
385#define strmatch(a,b) (!strcmp((a), (b)))
386
718e3744 387/* Zebra message flags */
388#define ZEBRA_FLAG_INTERNAL 0x01
389#define ZEBRA_FLAG_SELFROUTE 0x02
390#define ZEBRA_FLAG_BLACKHOLE 0x04
391#define ZEBRA_FLAG_IBGP 0x08
392#define ZEBRA_FLAG_SELECTED 0x10
718e3744 393#define ZEBRA_FLAG_STATIC 0x40
81dfcaa2 394#define ZEBRA_FLAG_REJECT 0x80
525c1839 395#define ZEBRA_FLAG_SCOPE_LINK 0x100
446bb95e 396#define ZEBRA_FLAG_FIB_OVERRIDE 0x200
718e3744 397
28d58fd7
VV
398/* Zebra FEC flags. */
399#define ZEBRA_FEC_REGISTER_LABEL_INDEX 0x1
400
718e3744 401#ifndef INADDR_LOOPBACK
402#define INADDR_LOOPBACK 0x7f000001 /* Internet address 127.0.0.1. */
403#endif
404
405/* Address family numbers from RFC1700. */
e978e1de
DS
406typedef enum {
407 AFI_IP = 1,
408 AFI_IP6 = 2,
17c7bb7b
RW
409 AFI_L2VPN = 3,
410 AFI_MAX = 4
e978e1de 411} afi_t;
718e3744 412
413/* Subsequent Address Family Identifier. */
414#define SAFI_UNICAST 1
415#define SAFI_MULTICAST 2
db19215a 416#define SAFI_MPLS_VPN 3
268fef65 417#define SAFI_RESERVED_4 4
9cabb64b 418#define SAFI_ENCAP 5
4d5b4f7b 419#define SAFI_RESERVED_5 5
924bf71c 420#define SAFI_EVPN 6
a64448ba
DS
421#define SAFI_LABELED_UNICAST 7
422#define SAFI_MAX 8
9cabb64b 423
b58ed1f8
DS
424#define IANA_SAFI_RESERVED 0
425#define IANA_SAFI_UNICAST 1
426#define IANA_SAFI_MULTICAST 2
a64448ba 427#define IANA_SAFI_LABELED_UNICAST 4
b58ed1f8
DS
428#define IANA_SAFI_ENCAP 7
429#define IANA_SAFI_MPLS_VPN 128
718e3744 430
90d82769
DS
431/*
432 * The above AFI and SAFI definitions are for internal use. The protocol
433 * definitions (IANA values) as for example used in BGP protocol packets
434 * are defined below and these will get mapped to/from the internal values
435 * in the appropriate places.
436 * The rationale is that the protocol (IANA) values may be sparse and are
437 * not optimal for use in data-structure sizing.
438 * Note: Only useful (i.e., supported) values are defined below.
439 */
440typedef enum {
441 IANA_AFI_RESERVED = 0,
442 IANA_AFI_IPV4 = 1,
443 IANA_AFI_IPV6 = 2,
444 IANA_AFI_L2VPN = 25,
445 IANA_AFI_IPMR = 128,
446 IANA_AFI_IP6MR = 129
447} iana_afi_t;
448
9cabb64b 449#define IANA_SAFI_RESERVED 0
450#define IANA_SAFI_UNICAST 1
451#define IANA_SAFI_MULTICAST 2
452#define IANA_SAFI_ENCAP 7
924bf71c 453#define IANA_SAFI_EVPN 70
9cabb64b 454#define IANA_SAFI_MPLS_VPN 128
718e3744 455
718e3744 456/* Default Administrative Distance of each protocol. */
457#define ZEBRA_KERNEL_DISTANCE_DEFAULT 0
458#define ZEBRA_CONNECT_DISTANCE_DEFAULT 0
459#define ZEBRA_STATIC_DISTANCE_DEFAULT 1
460#define ZEBRA_RIP_DISTANCE_DEFAULT 120
461#define ZEBRA_RIPNG_DISTANCE_DEFAULT 120
462#define ZEBRA_OSPF_DISTANCE_DEFAULT 110
463#define ZEBRA_OSPF6_DISTANCE_DEFAULT 110
9e867fe6 464#define ZEBRA_ISIS_DISTANCE_DEFAULT 115
718e3744 465#define ZEBRA_IBGP_DISTANCE_DEFAULT 200
466#define ZEBRA_EBGP_DISTANCE_DEFAULT 20
7ab5795a 467#define ZEBRA_TABLE_DISTANCE_DEFAULT 15
718e3744 468
469/* Flag manipulation macros. */
470#define CHECK_FLAG(V,F) ((V) & (F))
548e6f7d 471#define SET_FLAG(V,F) (V) |= (F)
472#define UNSET_FLAG(V,F) (V) &= ~(F)
fb018d25 473#define RESET_FLAG(V) (V) = 0
718e3744 474
5228ad27 475typedef u_int8_t safi_t;
718e3744 476
c1b9800a 477/* Zebra types. Used in Zserv message header. */
718e3744 478typedef u_int16_t zebra_size_t;
c1b9800a 479typedef u_int16_t zebra_command_t;
718e3744 480
b72ede27
FL
481/* VRF ID type. */
482typedef u_int16_t vrf_id_t;
483
dc9ffce8
CF
484typedef uint32_t route_tag_t;
485#define ROUTE_TAG_MAX UINT32_MAX
486#define ROUTE_TAG_PRI PRIu32
487
b58ed1f8 488static inline afi_t afi_iana2int (iana_afi_t afi)
9cabb64b 489{
490 if (afi == IANA_AFI_IPV4)
491 return AFI_IP;
492 if (afi == IANA_AFI_IPV6)
493 return AFI_IP6;
924bf71c
PG
494 if (afi == IANA_AFI_L2VPN)
495 return AFI_L2VPN;
9cabb64b 496 return AFI_MAX;
497}
498
b58ed1f8 499static inline iana_afi_t afi_int2iana (afi_t afi)
9cabb64b 500{
501 if (afi == AFI_IP)
502 return IANA_AFI_IPV4;
503 if (afi == AFI_IP6)
504 return IANA_AFI_IPV6;
924bf71c
PG
505 if (afi == AFI_L2VPN)
506 return IANA_AFI_L2VPN;
9cabb64b 507 return IANA_AFI_RESERVED;
508}
509
510static inline safi_t safi_iana2int (safi_t safi)
511{
512 if (safi == IANA_SAFI_UNICAST)
513 return SAFI_UNICAST;
514 if (safi == IANA_SAFI_MULTICAST)
515 return SAFI_MULTICAST;
516 if (safi == IANA_SAFI_MPLS_VPN)
517 return SAFI_MPLS_VPN;
518 if (safi == IANA_SAFI_ENCAP)
519 return SAFI_ENCAP;
924bf71c
PG
520 if (safi == IANA_SAFI_EVPN)
521 return SAFI_EVPN;
e05fd627
DS
522 if (safi == IANA_SAFI_LABELED_UNICAST)
523 return SAFI_LABELED_UNICAST;
9cabb64b 524 return SAFI_MAX;
525}
526
527static inline safi_t safi_int2iana (safi_t safi)
528{
529 if (safi == SAFI_UNICAST)
530 return IANA_SAFI_UNICAST;
531 if (safi == SAFI_MULTICAST)
532 return IANA_SAFI_MULTICAST;
533 if (safi == SAFI_MPLS_VPN)
534 return IANA_SAFI_MPLS_VPN;
535 if (safi == SAFI_ENCAP)
536 return IANA_SAFI_ENCAP;
924bf71c
PG
537 if (safi == SAFI_EVPN)
538 return IANA_SAFI_EVPN;
e05fd627
DS
539 if (safi == SAFI_LABELED_UNICAST)
540 return IANA_SAFI_LABELED_UNICAST;
9cabb64b 541 return IANA_SAFI_RESERVED;
542}
543
718e3744 544#endif /* _ZEBRA_H */