]> git.proxmox.com Git - mirror_frr.git/blob - zebra/zserv.h
redhat: Add option to build with RPKI
[mirror_frr.git] / zebra / zserv.h
1 /* Zebra daemon server header.
2 * Copyright (C) 1997, 98 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 */
20
21 #ifndef _ZEBRA_ZSERV_H
22 #define _ZEBRA_ZSERV_H
23
24 #include "rib.h"
25 #include "if.h"
26 #include "workqueue.h"
27 #include "vrf.h"
28 #include "routemap.h"
29 #include "vty.h"
30 #include "zclient.h"
31
32 #include "zebra/zebra_ns.h"
33 #include "zebra/zebra_pw.h"
34
35 /* Default port information. */
36 #define ZEBRA_VTY_PORT 2601
37
38 /* Default configuration filename. */
39 #define DEFAULT_CONFIG_FILE "zebra.conf"
40
41 #define ZEBRA_RMAP_DEFAULT_UPDATE_TIMER 5 /* disabled by default */
42
43 /* Client structure. */
44 struct zserv {
45 /* Client file descriptor. */
46 int sock;
47
48 /* Input/output buffer to the client. */
49 struct stream *ibuf;
50 struct stream *obuf;
51
52 /* Buffer of data waiting to be written to client. */
53 struct buffer *wb;
54
55 /* Threads for read/write. */
56 struct thread *t_read;
57 struct thread *t_write;
58
59 /* Thread for delayed close. */
60 struct thread *t_suicide;
61
62 /* default routing table this client munges */
63 int rtm_table;
64
65 /* This client's redistribute flag. */
66 struct redist_proto mi_redist[AFI_MAX][ZEBRA_ROUTE_MAX];
67 vrf_bitmap_t redist[AFI_MAX][ZEBRA_ROUTE_MAX];
68
69 /* Redistribute default route flag. */
70 vrf_bitmap_t redist_default;
71
72 /* Interface information. */
73 vrf_bitmap_t ifinfo;
74
75 /* Router-id information. */
76 vrf_bitmap_t ridinfo;
77
78 bool notify_owner;
79
80 /* client's protocol */
81 u_char proto;
82 u_short instance;
83 u_char is_synchronous;
84
85 /* Statistics */
86 u_int32_t redist_v4_add_cnt;
87 u_int32_t redist_v4_del_cnt;
88 u_int32_t redist_v6_add_cnt;
89 u_int32_t redist_v6_del_cnt;
90 u_int32_t v4_route_add_cnt;
91 u_int32_t v4_route_upd8_cnt;
92 u_int32_t v4_route_del_cnt;
93 u_int32_t v6_route_add_cnt;
94 u_int32_t v6_route_del_cnt;
95 u_int32_t v6_route_upd8_cnt;
96 u_int32_t connected_rt_add_cnt;
97 u_int32_t connected_rt_del_cnt;
98 u_int32_t ifup_cnt;
99 u_int32_t ifdown_cnt;
100 u_int32_t ifadd_cnt;
101 u_int32_t ifdel_cnt;
102 u_int32_t if_bfd_cnt;
103 u_int32_t bfd_peer_add_cnt;
104 u_int32_t bfd_peer_upd8_cnt;
105 u_int32_t bfd_peer_del_cnt;
106 u_int32_t bfd_peer_replay_cnt;
107 u_int32_t vrfadd_cnt;
108 u_int32_t vrfdel_cnt;
109 u_int32_t if_vrfchg_cnt;
110 u_int32_t bfd_client_reg_cnt;
111 u_int32_t vniadd_cnt;
112 u_int32_t vnidel_cnt;
113 u_int32_t l3vniadd_cnt;
114 u_int32_t l3vnidel_cnt;
115 u_int32_t macipadd_cnt;
116 u_int32_t macipdel_cnt;
117
118 time_t connect_time;
119 time_t last_read_time;
120 time_t last_write_time;
121 time_t nh_reg_time;
122 time_t nh_dereg_time;
123 time_t nh_last_upd_time;
124
125 int last_read_cmd;
126 int last_write_cmd;
127 };
128
129 /* Zebra instance */
130 struct zebra_t {
131 /* Thread master */
132 struct thread_master *master;
133 struct list *client_list;
134
135 /* default table */
136 u_int32_t rtm_table_default;
137
138 /* rib work queue */
139 #define ZEBRA_RIB_PROCESS_HOLD_TIME 10
140 struct work_queue *ribq;
141 struct meta_queue *mq;
142
143 /* LSP work queue */
144 struct work_queue *lsp_process_q;
145
146 #define ZEBRA_ZAPI_PACKETS_TO_PROCESS 10
147 u_int32_t packets_to_process;
148 };
149 extern struct zebra_t zebrad;
150 extern unsigned int multipath_num;
151
152 /* Prototypes. */
153 extern void zserv_init(void);
154 extern void zebra_zserv_socket_init(char *path);
155
156 extern int zsend_vrf_add(struct zserv *, struct zebra_vrf *);
157 extern int zsend_vrf_delete(struct zserv *, struct zebra_vrf *);
158
159 extern int zsend_interface_add(struct zserv *, struct interface *);
160 extern int zsend_interface_delete(struct zserv *, struct interface *);
161 extern int zsend_interface_addresses(struct zserv *, struct interface *);
162 extern int zsend_interface_address(int, struct zserv *, struct interface *,
163 struct connected *);
164 extern void nbr_connected_add_ipv6(struct interface *, struct in6_addr *);
165 extern void nbr_connected_delete_ipv6(struct interface *, struct in6_addr *);
166 extern int zsend_interface_update(int, struct zserv *, struct interface *);
167 extern int zsend_redistribute_route(int, struct zserv *, struct prefix *,
168 struct prefix *, struct route_entry *);
169 extern int zsend_router_id_update(struct zserv *, struct prefix *, vrf_id_t);
170 extern int zsend_interface_vrf_update(struct zserv *, struct interface *,
171 vrf_id_t);
172
173 extern int zsend_interface_link_params(struct zserv *, struct interface *);
174 extern int zsend_pw_update(struct zserv *, struct zebra_pw *);
175
176 extern int zsend_route_notify_owner(u_char proto, u_short instance,
177 vrf_id_t vrf_id, struct prefix *p,
178 enum zapi_route_notify_owner note);
179
180 extern void zserv_nexthop_num_warn(const char *, const struct prefix *,
181 const unsigned int);
182 extern int zebra_server_send_message(struct zserv *client);
183
184 extern struct zserv *zebra_find_client(u_char proto, u_short instance);
185
186 #if defined(HANDLE_ZAPI_FUZZING)
187 extern void zserv_read_file(char *input);
188 #endif
189
190 #endif /* _ZEBRA_ZEBRA_H */