]> git.proxmox.com Git - mirror_frr.git/blame - lib/zclient.c
pimd: Create ability to modify hell and hold timers per interface
[mirror_frr.git] / lib / zclient.c
CommitLineData
718e3744 1/* Zebra's client library.
2 * Copyright (C) 1999 Kunihiro Ishiguro
634f9ea2 3 * Copyright (C) 2005 Andrew J. Schorr
718e3744 4 *
5 * This file is part of GNU Zebra.
6 *
7 * GNU Zebra is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published
9 * by the Free Software Foundation; either version 2, or (at your
10 * option) any later version.
11 *
12 * GNU Zebra is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with GNU Zebra; see the file COPYING. If not, write to the
19 * Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
20 * MA 02111-1307, USA.
21 */
22
23#include <zebra.h>
24
25#include "prefix.h"
26#include "stream.h"
634f9ea2 27#include "buffer.h"
718e3744 28#include "network.h"
29#include "if.h"
30#include "log.h"
31#include "thread.h"
32#include "zclient.h"
33#include "memory.h"
34#include "table.h"
6b0655a2 35
718e3744 36/* Zebra client events. */
37enum event {ZCLIENT_SCHEDULE, ZCLIENT_READ, ZCLIENT_CONNECT};
38
39/* Prototype for event manager. */
40static void zclient_event (enum event, struct zclient *);
41
b5114685
VT
42char *zclient_serv_path = NULL;
43
718e3744 44/* This file local debug flag. */
45int zclient_debug = 0;
6b0655a2 46
718e3744 47/* Allocate zclient structure. */
48struct zclient *
4140ca4d 49zclient_new (struct thread_master *master)
718e3744 50{
51 struct zclient *zclient;
393deb9b 52 zclient = XCALLOC (MTYPE_ZCLIENT, sizeof (struct zclient));
718e3744 53
54 zclient->ibuf = stream_new (ZEBRA_MAX_PACKET_SIZ);
55 zclient->obuf = stream_new (ZEBRA_MAX_PACKET_SIZ);
634f9ea2 56 zclient->wb = buffer_new(0);
4140ca4d 57 zclient->master = master;
718e3744 58
59 return zclient;
60}
61
228da428 62/* This function is only called when exiting, because
634f9ea2 63 many parts of the code do not check for I/O errors, so they could
64 reference an invalid pointer if the structure was ever freed.
634f9ea2 65
228da428 66 Free zclient structure. */
718e3744 67void
68zclient_free (struct zclient *zclient)
69{
634f9ea2 70 if (zclient->ibuf)
71 stream_free(zclient->ibuf);
72 if (zclient->obuf)
73 stream_free(zclient->obuf);
74 if (zclient->wb)
75 buffer_free(zclient->wb);
76
718e3744 77 XFREE (MTYPE_ZCLIENT, zclient);
78}
79
7c8ff89e
DS
80int
81redist_check_instance (struct redist_proto *red, u_short instance)
82{
83 struct listnode *node;
84 u_short *id;
85
86 if (!red->instances)
87 return 0;
88
89 for (ALL_LIST_ELEMENTS_RO (red->instances, node, id))
90 if (*id == instance)
91 return 1;
92
93 return 0;
94}
95
96void
97redist_add_instance (struct redist_proto *red, u_short instance)
98{
99 u_short *in;
100
101 red->enabled = 1;
102
103 if (!red->instances)
104 red->instances = list_new();
105
106 in = (u_short *)calloc(1, sizeof(u_short));
107 *in = instance;
108 listnode_add (red->instances, in);
109}
110
111void
112redist_del_instance (struct redist_proto *red, u_short instance)
113{
114 struct listnode *node;
115 u_short *id = NULL;
116
117 if (!red->instances)
24873f0c 118 return;
7c8ff89e
DS
119
120 for (ALL_LIST_ELEMENTS_RO (red->instances, node, id))
121 if (*id == instance)
122 break;
123
124 if (id)
125 {
126 listnode_delete(red->instances, id);
127 if (!red->instances->count)
128 {
129 red->enabled = 0;
130 list_free(red->instances);
131 red->instances = NULL;
132 }
133 }
134}
135
718e3744 136/* Stop zebra client services. */
137void
138zclient_stop (struct zclient *zclient)
139{
140 if (zclient_debug)
8ddca704 141 zlog_debug ("zclient stopped");
718e3744 142
143 /* Stop threads. */
634f9ea2 144 THREAD_OFF(zclient->t_read);
145 THREAD_OFF(zclient->t_connect);
146 THREAD_OFF(zclient->t_write);
147
148 /* Reset streams. */
149 stream_reset(zclient->ibuf);
150 stream_reset(zclient->obuf);
151
152 /* Empty the write buffer. */
153 buffer_reset(zclient->wb);
718e3744 154
155 /* Close socket. */
156 if (zclient->sock >= 0)
157 {
158 close (zclient->sock);
159 zclient->sock = -1;
160 }
161 zclient->fail = 0;
162}
163
164void
165zclient_reset (struct zclient *zclient)
166{
7076bb2f 167 afi_t afi;
3d68677e 168
718e3744 169 zclient_stop (zclient);
3d68677e
DS
170
171 for (afi = AFI_IP; afi < AFI_MAX; afi++)
7076bb2f 172 redist_del_instance (&zclient->mi_redist[afi][zclient->redist_default], zclient->instance);
3d68677e 173
7c8ff89e 174 zclient_init (zclient, zclient->redist_default, zclient->instance);
718e3744 175}
176
b5114685
VT
177#ifdef HAVE_TCP_ZEBRA
178
718e3744 179/* Make socket to zebra daemon. Return zebra socket. */
b5114685 180static int
634f9ea2 181zclient_socket(void)
718e3744 182{
183 int sock;
184 int ret;
185 struct sockaddr_in serv;
186
187 /* We should think about IPv6 connection. */
188 sock = socket (AF_INET, SOCK_STREAM, 0);
189 if (sock < 0)
190 return -1;
191
192 /* Make server socket. */
193 memset (&serv, 0, sizeof (struct sockaddr_in));
194 serv.sin_family = AF_INET;
195 serv.sin_port = htons (ZEBRA_PORT);
6f0e3f6e 196#ifdef HAVE_STRUCT_SOCKADDR_IN_SIN_LEN
718e3744 197 serv.sin_len = sizeof (struct sockaddr_in);
6f0e3f6e 198#endif /* HAVE_STRUCT_SOCKADDR_IN_SIN_LEN */
718e3744 199 serv.sin_addr.s_addr = htonl (INADDR_LOOPBACK);
200
201 /* Connect to zebra. */
202 ret = connect (sock, (struct sockaddr *) &serv, sizeof (serv));
203 if (ret < 0)
204 {
4ecc09d3 205 zlog_warn ("%s connect failure: %d", __PRETTY_FUNCTION__, errno);
718e3744 206 close (sock);
207 return -1;
208 }
209 return sock;
210}
211
3414d035 212#else
b5114685 213
718e3744 214/* For sockaddr_un. */
215#include <sys/un.h>
216
b5114685 217static int
8c328f11 218zclient_socket_un (const char *path)
718e3744 219{
220 int ret;
221 int sock, len;
222 struct sockaddr_un addr;
223
224 sock = socket (AF_UNIX, SOCK_STREAM, 0);
225 if (sock < 0)
226 return -1;
227
228 /* Make server socket. */
229 memset (&addr, 0, sizeof (struct sockaddr_un));
230 addr.sun_family = AF_UNIX;
231 strncpy (addr.sun_path, path, strlen (path));
6f0e3f6e 232#ifdef HAVE_STRUCT_SOCKADDR_UN_SUN_LEN
718e3744 233 len = addr.sun_len = SUN_LEN(&addr);
234#else
235 len = sizeof (addr.sun_family) + strlen (addr.sun_path);
6f0e3f6e 236#endif /* HAVE_STRUCT_SOCKADDR_UN_SUN_LEN */
718e3744 237
238 ret = connect (sock, (struct sockaddr *) &addr, len);
239 if (ret < 0)
240 {
4ecc09d3 241 zlog_warn ("%s connect failure: %d", __PRETTY_FUNCTION__, errno);
718e3744 242 close (sock);
243 return -1;
244 }
245 return sock;
246}
247
3414d035
VT
248#endif /* HAVE_TCP_ZEBRA */
249
b5114685
VT
250/**
251 * Connect to zebra daemon.
252 * @param zclient a pointer to zclient structure
253 * @return socket fd just to make sure that connection established
254 * @see zclient_init
255 * @see zclient_new
256 */
257int
258zclient_socket_connect (struct zclient *zclient)
259{
260#ifdef HAVE_TCP_ZEBRA
261 zclient->sock = zclient_socket ();
262#else
12e41d03 263 zclient->sock = zclient_socket_un (zclient_serv_path_get());
b5114685
VT
264#endif
265 return zclient->sock;
266}
267
634f9ea2 268static int
269zclient_failed(struct zclient *zclient)
270{
271 zclient->fail++;
272 zclient_stop(zclient);
273 zclient_event(ZCLIENT_CONNECT, zclient);
274 return -1;
275}
276
277static int
278zclient_flush_data(struct thread *thread)
279{
280 struct zclient *zclient = THREAD_ARG(thread);
281
282 zclient->t_write = NULL;
283 if (zclient->sock < 0)
284 return -1;
285 switch (buffer_flush_available(zclient->wb, zclient->sock))
286 {
287 case BUFFER_ERROR:
288 zlog_warn("%s: buffer_flush_available failed on zclient fd %d, closing",
289 __func__, zclient->sock);
290 return zclient_failed(zclient);
291 break;
292 case BUFFER_PENDING:
4140ca4d 293 zclient->t_write = thread_add_write(zclient->master, zclient_flush_data,
634f9ea2 294 zclient, zclient->sock);
295 break;
296 case BUFFER_EMPTY:
297 break;
298 }
299 return 0;
300}
301
718e3744 302int
634f9ea2 303zclient_send_message(struct zclient *zclient)
304{
305 if (zclient->sock < 0)
306 return -1;
307 switch (buffer_write(zclient->wb, zclient->sock, STREAM_DATA(zclient->obuf),
308 stream_get_endp(zclient->obuf)))
309 {
310 case BUFFER_ERROR:
311 zlog_warn("%s: buffer_write failed to zclient fd %d, closing",
312 __func__, zclient->sock);
313 return zclient_failed(zclient);
314 break;
315 case BUFFER_EMPTY:
316 THREAD_OFF(zclient->t_write);
317 break;
318 case BUFFER_PENDING:
4140ca4d 319 THREAD_WRITE_ON(zclient->master, zclient->t_write,
634f9ea2 320 zclient_flush_data, zclient, zclient->sock);
321 break;
322 }
323 return 0;
324}
325
d211086a 326void
7076bb2f 327zclient_create_header (struct stream *s, uint16_t command, vrf_id_t vrf_id)
c1b9800a 328{
329 /* length placeholder, caller can update */
330 stream_putw (s, ZEBRA_HEADER_SIZE);
331 stream_putc (s, ZEBRA_HEADER_MARKER);
332 stream_putc (s, ZSERV_VERSION);
7076bb2f 333 stream_putw (s, vrf_id);
c1b9800a 334 stream_putw (s, command);
335}
336
634f9ea2 337/* Send simple Zebra message. */
338static int
7076bb2f 339zebra_message_send (struct zclient *zclient, int command, vrf_id_t vrf_id)
718e3744 340{
341 struct stream *s;
342
343 /* Get zclient output buffer. */
344 s = zclient->obuf;
345 stream_reset (s);
346
347 /* Send very simple command only Zebra message. */
7076bb2f 348 zclient_create_header (s, command, vrf_id);
c1b9800a 349
634f9ea2 350 return zclient_send_message(zclient);
718e3744 351}
352
2ea1ab1c
VT
353static int
354zebra_hello_send (struct zclient *zclient)
355{
356 struct stream *s;
357
358 if (zclient->redist_default)
359 {
360 s = zclient->obuf;
361 stream_reset (s);
362
7076bb2f
FL
363 /* The VRF ID in the HELLO message is always 0. */
364 zclient_create_header (s, ZEBRA_HELLO, VRF_DEFAULT);
2ea1ab1c 365 stream_putc (s, zclient->redist_default);
7c8ff89e 366 stream_putw (s, zclient->instance);
2ea1ab1c
VT
367 stream_putw_at (s, 0, stream_get_endp (s));
368 return zclient_send_message(zclient);
369 }
370
371 return 0;
372}
373
0e5223e7 374/* Send register requests to zebra daemon for the information in a VRF. */
7076bb2f 375void
0e5223e7 376zclient_send_reg_requests (struct zclient *zclient, vrf_id_t vrf_id)
7076bb2f
FL
377{
378 int i;
379 afi_t afi;
380
381 /* zclient is disabled. */
382 if (! zclient->enable)
383 return;
384
385 /* If not connected to the zebra yet. */
386 if (zclient->sock < 0)
387 return;
388
389 if (zclient_debug)
0e5223e7 390 zlog_debug ("%s: send register messages for VRF %u", __func__, vrf_id);
7076bb2f
FL
391
392 /* We need router-id information. */
393 zebra_message_send (zclient, ZEBRA_ROUTER_ID_ADD, vrf_id);
394
395 /* We need interface information. */
396 zebra_message_send (zclient, ZEBRA_INTERFACE_ADD, vrf_id);
397
398 /* Set unwanted redistribute route. */
399 for (afi = AFI_IP; afi < AFI_MAX; afi++)
400 vrf_bitmap_set (zclient->redist[afi][zclient->redist_default], vrf_id);
401
402 /* Flush all redistribute request. */
403 if (vrf_id == VRF_DEFAULT)
404 for (afi = AFI_IP; afi < AFI_MAX; afi++)
405 for (i = 0; i < ZEBRA_ROUTE_MAX; i++)
406 if (zclient->mi_redist[afi][i].enabled)
407 {
408 struct listnode *node;
409 u_short *id;
410
411 for (ALL_LIST_ELEMENTS_RO(zclient->mi_redist[afi][i].instances, node, id))
412 if (!(i == zclient->redist_default && *id == zclient->instance))
413 zebra_redistribute_send (ZEBRA_REDISTRIBUTE_ADD, zclient, afi, i,
414 *id, VRF_DEFAULT);
415 }
416
417 /* Flush all redistribute request. */
418 for (afi = AFI_IP; afi < AFI_MAX; afi++)
419 for (i = 0; i < ZEBRA_ROUTE_MAX; i++)
420 if (i != zclient->redist_default &&
421 vrf_bitmap_check (zclient->redist[afi][i], vrf_id))
422 zebra_redistribute_send (ZEBRA_REDISTRIBUTE_ADD, zclient, afi, i, 0, vrf_id);
423
424 /* If default information is needed. */
425 if (vrf_bitmap_check (zclient->default_information, VRF_DEFAULT))
426 zebra_message_send (zclient, ZEBRA_REDISTRIBUTE_DEFAULT_ADD, vrf_id);
427}
428
0e5223e7 429/* Send unregister requests to zebra daemon for the information in a VRF. */
430void
431zclient_send_dereg_requests (struct zclient *zclient, vrf_id_t vrf_id)
432{
433 int i;
434 afi_t afi;
435
436 /* zclient is disabled. */
437 if (! zclient->enable)
438 return;
439
440 /* If not connected to the zebra yet. */
441 if (zclient->sock < 0)
442 return;
443
444 if (zclient_debug)
445 zlog_debug ("%s: send deregister messages for VRF %u", __func__, vrf_id);
446
447 /* We need router-id information. */
448 zebra_message_send (zclient, ZEBRA_ROUTER_ID_DELETE, vrf_id);
449
450 /* We need interface information. */
451 zebra_message_send (zclient, ZEBRA_INTERFACE_DELETE, vrf_id);
452
453 /* Set unwanted redistribute route. */
454 for (afi = AFI_IP; afi < AFI_MAX; afi++)
455 vrf_bitmap_set (zclient->redist[afi][zclient->redist_default], vrf_id);
456
457 /* Flush all redistribute request. */
458 if (vrf_id == VRF_DEFAULT)
459 for (afi = AFI_IP; afi < AFI_MAX; afi++)
460 for (i = 0; i < ZEBRA_ROUTE_MAX; i++)
461 if (zclient->mi_redist[afi][i].enabled)
462 {
463 struct listnode *node;
464 u_short *id;
465
466 for (ALL_LIST_ELEMENTS_RO(zclient->mi_redist[afi][i].instances, node, id))
467 if (!(i == zclient->redist_default && *id == zclient->instance))
468 zebra_redistribute_send (ZEBRA_REDISTRIBUTE_DELETE, zclient, afi, i,
469 *id, VRF_DEFAULT);
470 }
471
472 /* Flush all redistribute request. */
473 for (afi = AFI_IP; afi < AFI_MAX; afi++)
474 for (i = 0; i < ZEBRA_ROUTE_MAX; i++)
475 if (i != zclient->redist_default &&
476 vrf_bitmap_check (zclient->redist[afi][i], vrf_id))
477 zebra_redistribute_send (ZEBRA_REDISTRIBUTE_DELETE, zclient, afi, i, 0, vrf_id);
478
479 /* If default information is needed. */
480 if (vrf_bitmap_check (zclient->default_information, VRF_DEFAULT))
481 zebra_message_send (zclient, ZEBRA_REDISTRIBUTE_DEFAULT_DELETE, vrf_id);
482}
483
4a04e5f7 484/* Send request to zebra daemon to start or stop RA. */
485void
486zclient_send_interface_radv_req (struct zclient *zclient, vrf_id_t vrf_id,
5c81b96a 487 struct interface *ifp, int enable, int ra_interval)
4a04e5f7 488{
489 struct stream *s;
490
491 /* zclient is disabled. */
492 if (!zclient->enable)
493 return;
494
495 /* If not connected to the zebra yet. */
496 if (zclient->sock < 0)
497 return;
498
499 /* Form and send message. */
500 s = zclient->obuf;
501 stream_reset (s);
502
503 if (enable)
504 zclient_create_header (s, ZEBRA_INTERFACE_ENABLE_RADV, vrf_id);
505 else
506 zclient_create_header (s, ZEBRA_INTERFACE_DISABLE_RADV, vrf_id);
507
508 stream_putl (s, ifp->ifindex);
5c81b96a 509 stream_putl (s, ra_interval);
4a04e5f7 510
511 stream_putw_at (s, 0, stream_get_endp (s));
512
513 zclient_send_message(zclient);
514}
515
718e3744 516/* Make connection to zebra daemon. */
517int
518zclient_start (struct zclient *zclient)
519{
7076bb2f
FL
520 if (zclient_debug)
521 zlog_info ("zclient_start is called");
522
523 /* zclient is disabled. */
524 if (! zclient->enable)
525 return 0;
718e3744 526
718e3744 527 /* If already connected to the zebra. */
528 if (zclient->sock >= 0)
529 return 0;
530
531 /* Check connect thread. */
532 if (zclient->t_connect)
533 return 0;
534
4ecc09d3
DS
535 /*
536 * If we fail to connect to the socket on initialization,
537 * Let's wait a second and see if we can reconnect.
538 * Cause if we don't connect, we never attempt to
539 * reconnect. On startup if zebra is slow we
540 * can get into this situation.
541 */
542 while (zclient_socket_connect(zclient) < 0 && zclient->fail < 5)
7076bb2f
FL
543 {
544 if (zclient_debug)
545 zlog_debug ("zclient connection fail");
546 zclient->fail++;
4ecc09d3
DS
547 sleep (1);
548 }
549
550 if (zclient->sock < 0)
551 {
7076bb2f
FL
552 zclient_event (ZCLIENT_CONNECT, zclient);
553 return -1;
554 }
718e3744 555
7076bb2f
FL
556 if (set_nonblocking(zclient->sock) < 0)
557 zlog_warn("%s: set_nonblocking(%d) failed", __func__, zclient->sock);
718e3744 558
7076bb2f
FL
559 /* Clear fail count. */
560 zclient->fail = 0;
561 if (zclient_debug)
562 zlog_debug ("zclient connect success with socket [%d]", zclient->sock);
718e3744 563
7076bb2f
FL
564 /* Create read thread. */
565 zclient_event (ZCLIENT_READ, zclient);
718e3744 566
7076bb2f 567 zebra_hello_send (zclient);
718e3744 568
7076bb2f
FL
569 /* Inform the successful connection. */
570 if (zclient->zebra_connected)
571 (*zclient->zebra_connected) (zclient);
718e3744 572
7076bb2f 573 return 0;
718e3744 574}
6b0655a2 575
078430f6
DS
576/* Initialize zebra client. Argument redist_default is unwanted
577 redistribute route type. */
578void
579zclient_init (struct zclient *zclient, int redist_default, u_short instance)
580{
581 int afi, i;
582
583 /* Enable zebra client connection by default. */
584 zclient->enable = 1;
585
586 /* Set -1 to the default socket value. */
587 zclient->sock = -1;
588
589 /* Clear redistribution flags. */
590 for (afi = AFI_IP; afi < AFI_MAX; afi++)
591 for (i = 0; i < ZEBRA_ROUTE_MAX; i++)
7076bb2f 592 zclient->redist[afi][i] = vrf_bitmap_init();
078430f6
DS
593
594 /* Set unwanted redistribute route. bgpd does not need BGP route
595 redistribution. */
596 zclient->redist_default = redist_default;
597 zclient->instance = instance;
598 /* Pending: make afi(s) an arg. */
599 for (afi = AFI_IP; afi < AFI_MAX; afi++)
7076bb2f 600 redist_add_instance (&zclient->mi_redist[afi][redist_default], instance);
078430f6
DS
601
602 /* Set default-information redistribute to zero. */
7076bb2f 603 zclient->default_information = vrf_bitmap_init ();;
078430f6
DS
604
605 if (zclient_debug)
606 zlog_debug ("zclient_start is called");
607
7076bb2f
FL
608 zclient_event (ZCLIENT_SCHEDULE, zclient);
609}
078430f6 610
7076bb2f
FL
611/* This function is a wrapper function for calling zclient_start from
612 timer or event thread. */
613static int
614zclient_connect (struct thread *t)
615{
616 struct zclient *zclient;
078430f6 617
7076bb2f
FL
618 zclient = THREAD_ARG (t);
619 zclient->t_connect = NULL;
078430f6 620
078430f6 621 if (zclient_debug)
7076bb2f 622 zlog_debug ("zclient_connect is called");
078430f6 623
7076bb2f 624 return zclient_start (zclient);
078430f6
DS
625}
626
0a589359 627 /*
628 * "xdr_encode"-like interface that allows daemon (client) to send
629 * a message to zebra server for a route that needs to be
630 * added/deleted to the kernel. Info about the route is specified
631 * by the caller in a struct zapi_ipv4. zapi_ipv4_read() then writes
632 * the info down the zclient socket using the stream_* functions.
633 *
634 * The corresponding read ("xdr_decode") function on the server
635 * side is zread_ipv4_add()/zread_ipv4_delete().
636 *
637 * 0 1 2 3 4 5 6 7 8 9 A B C D E F 0 1 2 3 4 5 6 7 8 9 A B C D E F
638 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
639 * | Length (2) | Command | Route Type |
640 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
641 * | ZEBRA Flags | Message Flags | Prefix length |
642 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
643 * | Destination IPv4 Prefix for route |
644 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
645 * | Nexthop count |
646 * +-+-+-+-+-+-+-+-+
647 *
648 *
649 * A number of IPv4 nexthop(s) or nexthop interface index(es) are then
650 * described, as per the Nexthop count. Each nexthop described as:
651 *
652 * +-+-+-+-+-+-+-+-+
653 * | Nexthop Type | Set to one of ZEBRA_NEXTHOP_*
654 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
655 * | IPv4 Nexthop address or Interface Index number |
656 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
657 *
658 * Alternatively, if the flags field has ZEBRA_FLAG_BLACKHOLE or
659 * ZEBRA_FLAG_REJECT is set then Nexthop count is set to 1, then _no_
660 * nexthop information is provided, and the message describes a prefix
661 * to blackhole or reject route.
662 *
c8a1cb5c
DS
663 * The original struct zapi_ipv4, zapi_ipv4_route() and zread_ipv4_*()
664 * infrastructure was built around the traditional (32-bit "gate OR
665 * ifindex") nexthop data unit. A special encoding can be used to feed
666 * onlink (64-bit "gate AND ifindex") nexthops into zapi_ipv4_route()
667 * using the same zapi_ipv4 structure. This is done by setting zapi_ipv4
668 * fields as follows:
669 * - .message |= ZAPI_MESSAGE_NEXTHOP | ZAPI_MESSAGE_ONLINK
670 * - .nexthop_num == .ifindex_num
671 * - .nexthop and .ifindex are filled with gate and ifindex parts of
672 * each compound nexthop, both in the same order
673 *
674 * zapi_ipv4_route() will produce two nexthop data units for each such
675 * interleaved 64-bit nexthop. On the zserv side of the socket it will be
676 * mapped to a singlle NEXTHOP_TYPE_IPV4_IFINDEX_OL RIB nexthop structure.
677 *
0a589359 678 * If ZAPI_MESSAGE_DISTANCE is set, the distance value is written as a 1
679 * byte value.
680 *
681 * If ZAPI_MESSAGE_METRIC is set, the metric value is written as an 8
682 * byte value.
683 *
0d9551dc
DS
684 * If ZAPI_MESSAGE_TAG is set, the tag value is written as a 2 byte value
685 *
0a589359 686 * XXX: No attention paid to alignment.
687 */
718e3744 688int
0a589359 689zapi_ipv4_route (u_char cmd, struct zclient *zclient, struct prefix_ipv4 *p,
690 struct zapi_ipv4 *api)
718e3744 691{
692 int i;
693 int psize;
694 struct stream *s;
695
696 /* Reset stream. */
697 s = zclient->obuf;
698 stream_reset (s);
7076bb2f
FL
699
700 zclient_create_header (s, cmd, api->vrf_id);
c1b9800a 701
702 /* Put type and nexthop. */
718e3744 703 stream_putc (s, api->type);
7c8ff89e 704 stream_putw (s, api->instance);
718e3744 705 stream_putc (s, api->flags);
706 stream_putc (s, api->message);
5a616c08 707 stream_putw (s, api->safi);
718e3744 708
718e3744 709 /* Put prefix information. */
710 psize = PSIZE (p->prefixlen);
711 stream_putc (s, p->prefixlen);
0a589359 712 stream_write (s, (u_char *) & p->prefix, psize);
718e3744 713
714 /* Nexthop, ifindex, distance and metric information. */
d44ca835 715 if (CHECK_FLAG (api->message, ZAPI_MESSAGE_NEXTHOP))
c8a1cb5c
DS
716 {
717 /* traditional 32-bit data units */
595db7f1 718 if (CHECK_FLAG (api->flags, ZEBRA_FLAG_BLACKHOLE))
719 {
720 stream_putc (s, 1);
721 stream_putc (s, ZEBRA_NEXTHOP_BLACKHOLE);
0a589359 722 /* XXX assert(api->nexthop_num == 0); */
723 /* XXX assert(api->ifindex_num == 0); */
595db7f1 724 }
725 else
726 stream_putc (s, api->nexthop_num + api->ifindex_num);
718e3744 727
728 for (i = 0; i < api->nexthop_num; i++)
595db7f1 729 {
730 stream_putc (s, ZEBRA_NEXTHOP_IPV4);
731 stream_put_in_addr (s, api->nexthop[i]);
732 }
718e3744 733 for (i = 0; i < api->ifindex_num; i++)
595db7f1 734 {
735 stream_putc (s, ZEBRA_NEXTHOP_IFINDEX);
736 stream_putl (s, api->ifindex[i]);
737 }
718e3744 738 }
739
740 if (CHECK_FLAG (api->message, ZAPI_MESSAGE_DISTANCE))
741 stream_putc (s, api->distance);
742 if (CHECK_FLAG (api->message, ZAPI_MESSAGE_METRIC))
743 stream_putl (s, api->metric);
0d9551dc
DS
744 if (CHECK_FLAG (api->message, ZAPI_MESSAGE_TAG))
745 stream_putw (s, api->tag);
718e3744 746
747 /* Put length at the first point of the stream. */
748 stream_putw_at (s, 0, stream_get_endp (s));
749
634f9ea2 750 return zclient_send_message(zclient);
718e3744 751}
752
753#ifdef HAVE_IPV6
8a92a8a0
DS
754int
755zapi_ipv4_route_ipv6_nexthop (u_char cmd, struct zclient *zclient,
756 struct prefix_ipv4 *p, struct zapi_ipv6 *api)
757{
758 int i;
759 int psize;
760 struct stream *s;
761
762 /* Reset stream. */
763 s = zclient->obuf;
764 stream_reset (s);
765
7076bb2f 766 zclient_create_header (s, cmd, api->vrf_id);
8a92a8a0
DS
767
768 /* Put type and nexthop. */
769 stream_putc (s, api->type);
770 stream_putw (s, api->instance);
771 stream_putc (s, api->flags);
772 stream_putc (s, api->message);
773 stream_putw (s, api->safi);
774
775 /* Put prefix information. */
776 psize = PSIZE (p->prefixlen);
777 stream_putc (s, p->prefixlen);
778 stream_write (s, (u_char *) & p->prefix, psize);
779
780 /* Nexthop, ifindex, distance and metric information. */
781 if (CHECK_FLAG (api->message, ZAPI_MESSAGE_NEXTHOP))
782 {
783 if (CHECK_FLAG (api->flags, ZEBRA_FLAG_BLACKHOLE))
784 {
785 stream_putc (s, 1);
786 stream_putc (s, ZEBRA_NEXTHOP_BLACKHOLE);
787 /* XXX assert(api->nexthop_num == 0); */
788 /* XXX assert(api->ifindex_num == 0); */
789 }
790 else
791 stream_putc (s, api->nexthop_num + api->ifindex_num);
792
793 for (i = 0; i < api->nexthop_num; i++)
794 {
795 stream_putc (s, ZEBRA_NEXTHOP_IPV6);
796 stream_write (s, (u_char *)api->nexthop[i], 16);
797 }
798 for (i = 0; i < api->ifindex_num; i++)
799 {
800 stream_putc (s, ZEBRA_NEXTHOP_IFINDEX);
801 stream_putl (s, api->ifindex[i]);
802 }
803 }
804
805 if (CHECK_FLAG (api->message, ZAPI_MESSAGE_DISTANCE))
806 stream_putc (s, api->distance);
807 if (CHECK_FLAG (api->message, ZAPI_MESSAGE_METRIC))
808 stream_putl (s, api->metric);
809 if (CHECK_FLAG (api->message, ZAPI_MESSAGE_TAG))
810 stream_putw (s, api->tag);
811
812 /* Put length at the first point of the stream. */
813 stream_putw_at (s, 0, stream_get_endp (s));
814
815 return zclient_send_message(zclient);
816}
817
718e3744 818int
0a589359 819zapi_ipv6_route (u_char cmd, struct zclient *zclient, struct prefix_ipv6 *p,
718e3744 820 struct zapi_ipv6 *api)
821{
822 int i;
823 int psize;
824 struct stream *s;
825
826 /* Reset stream. */
827 s = zclient->obuf;
828 stream_reset (s);
829
7076bb2f 830 zclient_create_header (s, cmd, api->vrf_id);
718e3744 831
c1b9800a 832 /* Put type and nexthop. */
718e3744 833 stream_putc (s, api->type);
7c8ff89e 834 stream_putw (s, api->instance);
718e3744 835 stream_putc (s, api->flags);
836 stream_putc (s, api->message);
c7ec179a 837 stream_putw (s, api->safi);
718e3744 838
839 /* Put prefix information. */
840 psize = PSIZE (p->prefixlen);
841 stream_putc (s, p->prefixlen);
842 stream_write (s, (u_char *)&p->prefix, psize);
843
844 /* Nexthop, ifindex, distance and metric information. */
845 if (CHECK_FLAG (api->message, ZAPI_MESSAGE_NEXTHOP))
846 {
c3c0ac83
DS
847 if (CHECK_FLAG (api->flags, ZEBRA_FLAG_BLACKHOLE))
848 {
849 stream_putc (s, 1);
850 stream_putc (s, ZEBRA_NEXTHOP_BLACKHOLE);
851 /* XXX assert(api->nexthop_num == 0); */
852 /* XXX assert(api->ifindex_num == 0); */
853 }
854 else
855 stream_putc (s, api->nexthop_num + api->ifindex_num);
718e3744 856
857 for (i = 0; i < api->nexthop_num; i++)
858 {
859 stream_putc (s, ZEBRA_NEXTHOP_IPV6);
860 stream_write (s, (u_char *)api->nexthop[i], 16);
861 }
862 for (i = 0; i < api->ifindex_num; i++)
863 {
864 stream_putc (s, ZEBRA_NEXTHOP_IFINDEX);
865 stream_putl (s, api->ifindex[i]);
866 }
867 }
868
869 if (CHECK_FLAG (api->message, ZAPI_MESSAGE_DISTANCE))
870 stream_putc (s, api->distance);
871 if (CHECK_FLAG (api->message, ZAPI_MESSAGE_METRIC))
872 stream_putl (s, api->metric);
0d9551dc
DS
873 if (CHECK_FLAG (api->message, ZAPI_MESSAGE_TAG))
874 stream_putw (s, api->tag);
718e3744 875
876 /* Put length at the first point of the stream. */
877 stream_putw_at (s, 0, stream_get_endp (s));
878
634f9ea2 879 return zclient_send_message(zclient);
718e3744 880}
718e3744 881#endif /* HAVE_IPV6 */
882
0a589359 883/*
884 * send a ZEBRA_REDISTRIBUTE_ADD or ZEBRA_REDISTRIBUTE_DELETE
885 * for the route type (ZEBRA_ROUTE_KERNEL etc.). The zebra server will
886 * then set/unset redist[type] in the client handle (a struct zserv) for the
887 * sending client
888 */
718e3744 889int
8bb0831e 890zebra_redistribute_send (int command, struct zclient *zclient, afi_t afi, int type,
7076bb2f 891 u_short instance, vrf_id_t vrf_id)
718e3744 892{
718e3744 893 struct stream *s;
894
634f9ea2 895 s = zclient->obuf;
896 stream_reset(s);
718e3744 897
7076bb2f 898 zclient_create_header (s, command, vrf_id);
8bb0831e 899 stream_putc (s, afi);
718e3744 900 stream_putc (s, type);
7c8ff89e 901 stream_putw (s, instance);
c1b9800a 902
903 stream_putw_at (s, 0, stream_get_endp (s));
904
634f9ea2 905 return zclient_send_message(zclient);
718e3744 906}
907
18a6dce6 908/* Router-id update from zebra daemon. */
909void
910zebra_router_id_update_read (struct stream *s, struct prefix *rid)
911{
912 int plen;
913
914 /* Fetch interface address. */
915 rid->family = stream_getc (s);
916
917 plen = prefix_blen (rid);
918 stream_get (&rid->u.prefix, s, plen);
919 rid->prefixlen = stream_getc (s);
920}
921
718e3744 922/* Interface addition from zebra daemon. */
0a589359 923/*
924 * The format of the message sent with type ZEBRA_INTERFACE_ADD or
925 * ZEBRA_INTERFACE_DELETE from zebra to the client is:
926 * 0 1 2 3
927 * 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
928 * +-+-+-+-+-+-+-+-+
929 * | type |
930 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
931 * | ifname |
932 * | |
933 * | |
934 * | |
935 * | |
936 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
937 * | ifindex |
938 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
939 * | if_flags |
c77d4546 940 * | |
0a589359 941 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
942 * | metric |
943 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
944 * | ifmtu |
945 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
946 * | ifmtu6 |
947 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
948 * | bandwidth |
949 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
950 * | sockaddr_dl |
951 * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
952 */
953
2fcc254e
DS
954static void
955zclient_vrf_add (struct stream *s, vrf_id_t vrf_id)
1892f15e
DS
956{
957 struct vrf *vrf;
958 char vrfname_tmp[VRF_NAMSIZ];
959
960 /* Read interface name. */
961 stream_get (vrfname_tmp, s, VRF_NAMSIZ);
962
963 /* Lookup/create vrf by vrf_id. */
964 vrf = vrf_get (vrf_id, vrfname_tmp);
965
2fcc254e 966 vrf_enable (vrf);
1892f15e
DS
967}
968
2fcc254e
DS
969static void
970zclient_vrf_delete (struct stream *s, vrf_id_t vrf_id)
1892f15e
DS
971{
972 struct vrf *vrf;
973
974 /* Lookup vrf by vrf_id. */
975 vrf = vrf_lookup (vrf_id);
976
beef1990
DS
977 /*
978 * If a routing protocol doesn't know about a
979 * vrf that is about to be deleted. There is
980 * no point in attempting to delete it.
981 */
982 if (!vrf)
983 return;
984
2fcc254e 985 vrf_delete (vrf);
1892f15e
DS
986}
987
718e3744 988struct interface *
7076bb2f 989zebra_interface_add_read (struct stream *s, vrf_id_t vrf_id)
718e3744 990{
991 struct interface *ifp;
02ff83c5 992 char ifname_tmp[INTERFACE_NAMSIZ];
718e3744 993
994 /* Read interface name. */
995 stream_get (ifname_tmp, s, INTERFACE_NAMSIZ);
996
a349198f 997 /* Lookup/create interface by name. */
7076bb2f
FL
998 ifp = if_get_by_name_len_vrf (ifname_tmp,
999 strnlen (ifname_tmp, INTERFACE_NAMSIZ),
85f9da7f 1000 vrf_id, 0);
718e3744 1001
51d4ef83 1002 zebra_interface_if_set_value (s, ifp);
718e3744 1003
718e3744 1004 return ifp;
1005}
1006
0a589359 1007/*
1008 * Read interface up/down msg (ZEBRA_INTERFACE_UP/ZEBRA_INTERFACE_DOWN)
1009 * from zebra server. The format of this message is the same as
1010 * that sent for ZEBRA_INTERFACE_ADD/ZEBRA_INTERFACE_DELETE (see
1011 * comments for zebra_interface_add_read), except that no sockaddr_dl
1012 * is sent at the tail of the message.
1013 */
718e3744 1014struct interface *
7076bb2f 1015zebra_interface_state_read (struct stream *s, vrf_id_t vrf_id)
718e3744 1016{
1017 struct interface *ifp;
02ff83c5 1018 char ifname_tmp[INTERFACE_NAMSIZ];
718e3744 1019
1020 /* Read interface name. */
1021 stream_get (ifname_tmp, s, INTERFACE_NAMSIZ);
1022
1023 /* Lookup this by interface index. */
7076bb2f
FL
1024 ifp = if_lookup_by_name_len_vrf (ifname_tmp,
1025 strnlen (ifname_tmp, INTERFACE_NAMSIZ),
1026 vrf_id);
b4dd5eaa 1027 if (ifp == NULL)
1028 {
1029 zlog_warn ("INTERFACE_STATE: Cannot find IF %s in VRF %d",
1030 ifname_tmp, vrf_id);
1031 return NULL;
1032 }
718e3744 1033
51d4ef83 1034 zebra_interface_if_set_value (s, ifp);
718e3744 1035
1036 return ifp;
1037}
1038
0a589359 1039/*
1040 * format of message for address additon is:
1041 * 0
1042 * 0 1 2 3 4 5 6 7
1043 * +-+-+-+-+-+-+-+-+
1044 * | type | ZEBRA_INTERFACE_ADDRESS_ADD or
1045 * +-+-+-+-+-+-+-+-+ ZEBRA_INTERFACE_ADDRES_DELETE
1046 * | |
1047 * + +
1048 * | ifindex |
1049 * + +
1050 * | |
1051 * + +
1052 * | |
1053 * +-+-+-+-+-+-+-+-+
1054 * | ifc_flags | flags for connected address
1055 * +-+-+-+-+-+-+-+-+
1056 * | addr_family |
1057 * +-+-+-+-+-+-+-+-+
1058 * | addr... |
1059 * : :
1060 * | |
1061 * +-+-+-+-+-+-+-+-+
1062 * | addr_len | len of addr. E.g., addr_len = 4 for ipv4 addrs.
1063 * +-+-+-+-+-+-+-+-+
1064 * | daddr.. |
1065 * : :
1066 * | |
1067 * +-+-+-+-+-+-+-+-+
1068 *
1069 */
1070
18a6dce6 1071void
1072zebra_interface_if_set_value (struct stream *s, struct interface *ifp)
1073{
1074 /* Read interface's index. */
1075 ifp->ifindex = stream_getl (s);
508ec910 1076 ifp->status = stream_getc (s);
18a6dce6 1077
1078 /* Read interface's value. */
c77d4546 1079 ifp->flags = stream_getq (s);
244c1cdc
DS
1080 ifp->ptm_enable = stream_getc (s);
1081 ifp->ptm_status = stream_getc (s);
18a6dce6 1082 ifp->metric = stream_getl (s);
1083 ifp->mtu = stream_getl (s);
508ec910 1084 ifp->mtu6 = stream_getl (s);
18a6dce6 1085 ifp->bandwidth = stream_getl (s);
51d4ef83 1086#ifdef HAVE_STRUCT_SOCKADDR_DL
ca3ccd87 1087 stream_get (&ifp->sdl, s, sizeof (ifp->sdl_storage));
51d4ef83
JB
1088#else
1089 ifp->hw_addr_len = stream_getl (s);
1090 if (ifp->hw_addr_len)
cbe0a6a1 1091 stream_get (ifp->hw_addr, s, MIN(ifp->hw_addr_len, INTERFACE_HWADDR_MAX));
51d4ef83 1092#endif /* HAVE_STRUCT_SOCKADDR_DL */
18a6dce6 1093}
1094
3fb9cd6e 1095static int
1096memconstant(const void *s, int c, size_t n)
1097{
1098 const u_char *p = s;
1099
1100 while (n-- > 0)
1101 if (*p++ != c)
1102 return 0;
1103 return 1;
1104}
1105
d5a5c8f0 1106
718e3744 1107struct connected *
7076bb2f 1108zebra_interface_address_read (int type, struct stream *s, vrf_id_t vrf_id)
718e3744 1109{
1110 unsigned int ifindex;
1111 struct interface *ifp;
1112 struct connected *ifc;
0a589359 1113 struct prefix p, d;
718e3744 1114 int family;
1115 int plen;
0a589359 1116 u_char ifc_flags;
718e3744 1117
0a589359 1118 memset (&p, 0, sizeof(p));
1119 memset (&d, 0, sizeof(d));
718e3744 1120
1121 /* Get interface index. */
1122 ifindex = stream_getl (s);
1123
1124 /* Lookup index. */
7076bb2f 1125 ifp = if_lookup_by_index_vrf (ifindex, vrf_id);
718e3744 1126 if (ifp == NULL)
1127 {
b4dd5eaa 1128 zlog_warn ("INTERFACE_ADDRESS_%s: Cannot find IF %u in VRF %d",
1129 (type == ZEBRA_INTERFACE_ADDRESS_ADD) ? "ADD" : "DEL",
1130 ifindex, vrf_id);
718e3744 1131 return NULL;
1132 }
1133
1134 /* Fetch flag. */
0a589359 1135 ifc_flags = stream_getc (s);
718e3744 1136
1137 /* Fetch interface address. */
1138 family = p.family = stream_getc (s);
1139
0a589359 1140 plen = prefix_blen (&p);
1141 stream_get (&p.u.prefix, s, plen);
718e3744 1142 p.prefixlen = stream_getc (s);
1143
1144 /* Fetch destination address. */
0a589359 1145 stream_get (&d.u.prefix, s, plen);
718e3744 1146 d.family = family;
1147
0a589359 1148 if (type == ZEBRA_INTERFACE_ADDRESS_ADD)
1149 {
38485402
DS
1150 ifc = connected_lookup_prefix_exact (ifp, &p);
1151 if (!ifc)
1152 {
1153 /* N.B. NULL destination pointers are encoded as all zeroes */
1154 ifc = connected_add_by_prefix(ifp, &p, (memconstant(&d.u.prefix,0,plen) ?
1155 NULL : &d));
1156 }
1157 if (ifc)
e4529636
AS
1158 {
1159 ifc->flags = ifc_flags;
1160 if (ifc->destination)
1161 ifc->destination->prefixlen = ifc->address->prefixlen;
90444ca3
DL
1162 else if (CHECK_FLAG(ifc->flags, ZEBRA_IFA_PEER))
1163 {
1164 /* carp interfaces on OpenBSD with 0.0.0.0/0 as "peer" */
4690c7d7 1165 char buf[PREFIX2STR_BUFFER];
90444ca3
DL
1166 prefix2str (ifc->address, buf, sizeof(buf));
1167 zlog_warn("warning: interface %s address %s "
1168 "with peer flag set, but no peer address!",
1169 ifp->name, buf);
1170 UNSET_FLAG(ifc->flags, ZEBRA_IFA_PEER);
1171 }
e4529636 1172 }
0a589359 1173 }
1174 else
1175 {
1176 assert (type == ZEBRA_INTERFACE_ADDRESS_DELETE);
1177 ifc = connected_delete_by_prefix(ifp, &p);
1178 }
718e3744 1179
1180 return ifc;
1181}
0a589359 1182
a80beece
DS
1183/*
1184 * format of message for neighbor connected address is:
1185 * 0
1186 * 0 1 2 3 4 5 6 7
1187 * +-+-+-+-+-+-+-+-+
1188 * | type | ZEBRA_INTERFACE_NBR_ADDRESS_ADD or
1189 * +-+-+-+-+-+-+-+-+ ZEBRA_INTERFACE_NBR_ADDRES_DELETE
1190 * | |
1191 * + +
1192 * | ifindex |
1193 * + +
1194 * | |
1195 * + +
1196 * | |
1197 * +-+-+-+-+-+-+-+-+
1198 * | addr_family |
1199 * +-+-+-+-+-+-+-+-+
1200 * | addr... |
1201 * : :
1202 * | |
1203 * +-+-+-+-+-+-+-+-+
1204 * | addr_len | len of addr.
1205 * +-+-+-+-+-+-+-+-+
1206 */
1207struct nbr_connected *
7076bb2f 1208zebra_interface_nbr_address_read (int type, struct stream *s, vrf_id_t vrf_id)
a80beece
DS
1209{
1210 unsigned int ifindex;
1211 struct interface *ifp;
1212 struct prefix p;
1213 struct nbr_connected *ifc;
1214
1215 /* Get interface index. */
1216 ifindex = stream_getl (s);
1217
1218 /* Lookup index. */
f1aa3df6 1219 ifp = if_lookup_by_index_vrf (ifindex, vrf_id);
a80beece
DS
1220 if (ifp == NULL)
1221 {
f1aa3df6 1222 zlog_warn ("INTERFACE_NBR_%s: Cannot find IF %u in VRF %d",
1223 (type == ZEBRA_INTERFACE_NBR_ADDRESS_ADD) ? "ADD" : "DELETE",
1224 ifindex, vrf_id);
a80beece
DS
1225 return NULL;
1226 }
1227
1228 p.family = stream_getc (s);
1229 stream_get (&p.u.prefix, s, prefix_blen (&p));
1230 p.prefixlen = stream_getc (s);
1231
1232 if (type == ZEBRA_INTERFACE_NBR_ADDRESS_ADD)
1233 {
1234 /* Currently only supporting P2P links, so any new RA source address is
1235 considered as the replacement of the previously learnt Link-Local address. */
1236 if (!(ifc = listnode_head(ifp->nbr_connected)))
1237 {
1238 ifc = nbr_connected_new ();
1239 ifc->address = prefix_new ();
1240 ifc->ifp = ifp;
1241 listnode_add (ifp->nbr_connected, ifc);
1242 }
1243
1244 prefix_copy(ifc->address, &p);
1245 }
1246 else
1247 {
1248 assert (type == ZEBRA_INTERFACE_NBR_ADDRESS_DELETE);
1249
1250 ifc = nbr_connected_check(ifp, &p);
1251 if (ifc)
1252 listnode_delete (ifp->nbr_connected, ifc);
1253 }
1254
1255 return ifc;
1256}
6b0655a2 1257
c8e264b6 1258struct interface *
1259zebra_interface_vrf_update_read (struct stream *s, vrf_id_t vrf_id,
1260 vrf_id_t *new_vrf_id)
1261{
1262 unsigned int ifindex;
1263 struct interface *ifp;
1264 vrf_id_t new_id = VRF_DEFAULT;
1265
1266 /* Get interface index. */
1267 ifindex = stream_getl (s);
1268
1269 /* Lookup interface. */
1270 ifp = if_lookup_by_index_vrf (ifindex, vrf_id);
1271 if (ifp == NULL)
1272 {
1273 zlog_warn ("INTERFACE_VRF_UPDATE: Cannot find IF %u in VRF %d",
1274 ifindex, vrf_id);
1275 return NULL;
1276 }
1277
1278 /* Fetch new VRF Id. */
1279 new_id = stream_getw (s);
1280
1281 *new_vrf_id = new_id;
1282 return ifp;
1283}
1284
718e3744 1285/* Zebra client message read function. */
634f9ea2 1286static int
718e3744 1287zclient_read (struct thread *thread)
1288{
634f9ea2 1289 size_t already;
c1b9800a 1290 uint16_t length, command;
1291 uint8_t marker, version;
7076bb2f 1292 vrf_id_t vrf_id;
718e3744 1293 struct zclient *zclient;
1294
1295 /* Get socket to zebra. */
718e3744 1296 zclient = THREAD_ARG (thread);
1297 zclient->t_read = NULL;
1298
634f9ea2 1299 /* Read zebra header (if we don't have it already). */
1300 if ((already = stream_get_endp(zclient->ibuf)) < ZEBRA_HEADER_SIZE)
718e3744 1301 {
634f9ea2 1302 ssize_t nbyte;
1303 if (((nbyte = stream_read_try(zclient->ibuf, zclient->sock,
1304 ZEBRA_HEADER_SIZE-already)) == 0) ||
1305 (nbyte == -1))
1306 {
1307 if (zclient_debug)
1308 zlog_debug ("zclient connection closed socket [%d].", zclient->sock);
1309 return zclient_failed(zclient);
1310 }
1311 if (nbyte != (ssize_t)(ZEBRA_HEADER_SIZE-already))
1312 {
1313 /* Try again later. */
1314 zclient_event (ZCLIENT_READ, zclient);
1315 return 0;
1316 }
1317 already = ZEBRA_HEADER_SIZE;
718e3744 1318 }
1319
634f9ea2 1320 /* Reset to read from the beginning of the incoming packet. */
1321 stream_set_getp(zclient->ibuf, 0);
718e3744 1322
c1b9800a 1323 /* Fetch header values. */
718e3744 1324 length = stream_getw (zclient->ibuf);
c1b9800a 1325 marker = stream_getc (zclient->ibuf);
1326 version = stream_getc (zclient->ibuf);
7076bb2f 1327 vrf_id = stream_getw (zclient->ibuf);
c1b9800a 1328 command = stream_getw (zclient->ibuf);
1329
1330 if (marker != ZEBRA_HEADER_MARKER || version != ZSERV_VERSION)
1331 {
1332 zlog_err("%s: socket %d version mismatch, marker %d, version %d",
1333 __func__, zclient->sock, marker, version);
1334 return zclient_failed(zclient);
1335 }
1336
634f9ea2 1337 if (length < ZEBRA_HEADER_SIZE)
1338 {
1339 zlog_err("%s: socket %d message length %u is less than %d ",
1340 __func__, zclient->sock, length, ZEBRA_HEADER_SIZE);
1341 return zclient_failed(zclient);
1342 }
1343
718e3744 1344 /* Length check. */
634f9ea2 1345 if (length > STREAM_SIZE(zclient->ibuf))
718e3744 1346 {
634f9ea2 1347 struct stream *ns;
1348 zlog_warn("%s: message size %u exceeds buffer size %lu, expanding...",
1349 __func__, length, (u_long)STREAM_SIZE(zclient->ibuf));
1350 ns = stream_new(length);
1351 stream_copy(ns, zclient->ibuf);
718e3744 1352 stream_free (zclient->ibuf);
634f9ea2 1353 zclient->ibuf = ns;
718e3744 1354 }
718e3744 1355
1356 /* Read rest of zebra packet. */
634f9ea2 1357 if (already < length)
1358 {
1359 ssize_t nbyte;
1360 if (((nbyte = stream_read_try(zclient->ibuf, zclient->sock,
1361 length-already)) == 0) ||
1362 (nbyte == -1))
1363 {
1364 if (zclient_debug)
1365 zlog_debug("zclient connection closed socket [%d].", zclient->sock);
1366 return zclient_failed(zclient);
1367 }
1368 if (nbyte != (ssize_t)(length-already))
1369 {
1370 /* Try again later. */
1371 zclient_event (ZCLIENT_READ, zclient);
1372 return 0;
1373 }
1374 }
1375
1376 length -= ZEBRA_HEADER_SIZE;
718e3744 1377
0a589359 1378 if (zclient_debug)
7076bb2f 1379 zlog_debug("zclient 0x%p command 0x%x VRF %u\n", (void *)zclient, command, vrf_id);
0a589359 1380
718e3744 1381 switch (command)
1382 {
18a6dce6 1383 case ZEBRA_ROUTER_ID_UPDATE:
1384 if (zclient->router_id_update)
7076bb2f 1385 (*zclient->router_id_update) (command, zclient, length, vrf_id);
18a6dce6 1386 break;
1892f15e 1387 case ZEBRA_VRF_ADD:
2fcc254e 1388 zclient_vrf_add (zclient->ibuf, vrf_id);
1892f15e
DS
1389 break;
1390 case ZEBRA_VRF_DELETE:
2fcc254e 1391 zclient_vrf_delete (zclient->ibuf, vrf_id);
1892f15e 1392 break;
718e3744 1393 case ZEBRA_INTERFACE_ADD:
1394 if (zclient->interface_add)
7076bb2f 1395 (*zclient->interface_add) (command, zclient, length, vrf_id);
718e3744 1396 break;
1397 case ZEBRA_INTERFACE_DELETE:
1398 if (zclient->interface_delete)
7076bb2f 1399 (*zclient->interface_delete) (command, zclient, length, vrf_id);
718e3744 1400 break;
1401 case ZEBRA_INTERFACE_ADDRESS_ADD:
1402 if (zclient->interface_address_add)
7076bb2f 1403 (*zclient->interface_address_add) (command, zclient, length, vrf_id);
718e3744 1404 break;
1405 case ZEBRA_INTERFACE_ADDRESS_DELETE:
1406 if (zclient->interface_address_delete)
7076bb2f 1407 (*zclient->interface_address_delete) (command, zclient, length, vrf_id);
718e3744 1408 break;
68fe91d6 1409 case ZEBRA_INTERFACE_BFD_DEST_UPDATE:
1410 if (zclient->interface_bfd_dest_update)
7076bb2f 1411 (*zclient->interface_bfd_dest_update) (command, zclient, length, vrf_id);
d5a5c8f0 1412 break;
a80beece
DS
1413 case ZEBRA_INTERFACE_NBR_ADDRESS_ADD:
1414 if (zclient->interface_nbr_address_add)
7076bb2f 1415 (*zclient->interface_nbr_address_add) (command, zclient, length, vrf_id);
a80beece
DS
1416 break;
1417 case ZEBRA_INTERFACE_NBR_ADDRESS_DELETE:
1418 if (zclient->interface_nbr_address_delete)
7076bb2f 1419 (*zclient->interface_nbr_address_delete) (command, zclient, length, vrf_id);
a80beece 1420 break;
718e3744 1421 case ZEBRA_INTERFACE_UP:
1422 if (zclient->interface_up)
7076bb2f 1423 (*zclient->interface_up) (command, zclient, length, vrf_id);
718e3744 1424 break;
1425 case ZEBRA_INTERFACE_DOWN:
1426 if (zclient->interface_down)
7076bb2f 1427 (*zclient->interface_down) (command, zclient, length, vrf_id);
c8e264b6 1428 break;
1429 case ZEBRA_INTERFACE_VRF_UPDATE:
1430 if (zclient->interface_vrf_update)
1431 (*zclient->interface_vrf_update) (command, zclient, length, vrf_id);
718e3744 1432 break;
1433 case ZEBRA_IPV4_ROUTE_ADD:
1434 if (zclient->ipv4_route_add)
7076bb2f 1435 (*zclient->ipv4_route_add) (command, zclient, length, vrf_id);
718e3744 1436 break;
1437 case ZEBRA_IPV4_ROUTE_DELETE:
1438 if (zclient->ipv4_route_delete)
7076bb2f 1439 (*zclient->ipv4_route_delete) (command, zclient, length, vrf_id);
718e3744 1440 break;
1441 case ZEBRA_IPV6_ROUTE_ADD:
1442 if (zclient->ipv6_route_add)
7076bb2f 1443 (*zclient->ipv6_route_add) (command, zclient, length, vrf_id);
718e3744 1444 break;
1445 case ZEBRA_IPV6_ROUTE_DELETE:
1446 if (zclient->ipv6_route_delete)
7076bb2f 1447 (*zclient->ipv6_route_delete) (command, zclient, length, vrf_id);
718e3744 1448 break;
fb018d25
DS
1449 case ZEBRA_NEXTHOP_UPDATE:
1450 if (zclient_debug)
1451 zlog_debug("zclient rcvd nexthop update\n");
1452 if (zclient->nexthop_update)
7076bb2f 1453 (*zclient->nexthop_update) (command, zclient, length, vrf_id);
fb018d25 1454 break;
078430f6
DS
1455 case ZEBRA_IMPORT_CHECK_UPDATE:
1456 if (zclient_debug)
1457 zlog_debug("zclient rcvd import check update\n");
1458 if (zclient->import_check_update)
7076bb2f 1459 (*zclient->import_check_update) (command, zclient, length, vrf_id);
078430f6 1460 break;
c43ed2e4
DS
1461 case ZEBRA_BFD_DEST_REPLAY:
1462 if (zclient->bfd_dest_replay)
7076bb2f 1463 (*zclient->bfd_dest_replay) (command, zclient, length, vrf_id);
c43ed2e4 1464 break;
5048fe14 1465 case ZEBRA_REDISTRIBUTE_IPV4_ADD:
1466 if (zclient->redistribute_route_ipv4_add)
7076bb2f 1467 (*zclient->redistribute_route_ipv4_add) (command, zclient, length, vrf_id);
5048fe14 1468 break;
1469 case ZEBRA_REDISTRIBUTE_IPV4_DEL:
1470 if (zclient->redistribute_route_ipv4_del)
7076bb2f 1471 (*zclient->redistribute_route_ipv4_del) (command, zclient, length, vrf_id);
5048fe14 1472 break;
1473 case ZEBRA_REDISTRIBUTE_IPV6_ADD:
1474 if (zclient->redistribute_route_ipv6_add)
7076bb2f 1475 (*zclient->redistribute_route_ipv6_add) (command, zclient, length, vrf_id);
5048fe14 1476 break;
1477 case ZEBRA_REDISTRIBUTE_IPV6_DEL:
1478 if (zclient->redistribute_route_ipv6_del)
7076bb2f 1479 (*zclient->redistribute_route_ipv6_del) (command, zclient, length, vrf_id);
5048fe14 1480 break;
718e3744 1481 default:
1482 break;
1483 }
1484
634f9ea2 1485 if (zclient->sock < 0)
1486 /* Connection was closed during packet processing. */
1487 return -1;
1488
718e3744 1489 /* Register read thread. */
634f9ea2 1490 stream_reset(zclient->ibuf);
718e3744 1491 zclient_event (ZCLIENT_READ, zclient);
1492
1493 return 0;
1494}
1495
1496void
8bb0831e 1497zclient_redistribute (int command, struct zclient *zclient, afi_t afi, int type,
7076bb2f 1498 u_short instance, vrf_id_t vrf_id)
718e3744 1499{
718e3744 1500
7076bb2f
FL
1501 if (instance) {
1502 if (command == ZEBRA_REDISTRIBUTE_ADD)
1503 {
1504 if (redist_check_instance(&zclient->mi_redist[afi][type], instance))
1505 return;
1506 redist_add_instance(&zclient->mi_redist[afi][type], instance);
1507 }
1508 else
1509 {
1510 if (!redist_check_instance(&zclient->mi_redist[afi][type], instance))
1511 return;
1512 redist_del_instance(&zclient->mi_redist[afi][type], instance);
1513 }
1514
1515 } else {
1516 if (command == ZEBRA_REDISTRIBUTE_ADD)
1517 {
1518 if (vrf_bitmap_check (zclient->redist[afi][type], vrf_id))
1519 return;
1520 vrf_bitmap_set (zclient->redist[afi][type], vrf_id);
1521 }
1522 else
1523 {
1524 if (!vrf_bitmap_check (zclient->redist[afi][type], vrf_id))
1525 return;
1526 vrf_bitmap_unset (zclient->redist[afi][type], vrf_id);
1527 }
1528 }
718e3744 1529
1530 if (zclient->sock > 0)
7076bb2f 1531 zebra_redistribute_send (command, zclient, afi, type, instance, vrf_id);
718e3744 1532}
1533
718e3744 1534
1535void
7076bb2f
FL
1536zclient_redistribute_default (int command, struct zclient *zclient,
1537 vrf_id_t vrf_id)
718e3744 1538{
718e3744 1539
0a589359 1540 if (command == ZEBRA_REDISTRIBUTE_DEFAULT_ADD)
1541 {
7076bb2f 1542 if (vrf_bitmap_check (zclient->default_information, vrf_id))
0a589359 1543 return;
7076bb2f 1544 vrf_bitmap_set (zclient->default_information, vrf_id);
0a589359 1545 }
1546 else
1547 {
7076bb2f 1548 if (!vrf_bitmap_check (zclient->default_information, vrf_id))
0a589359 1549 return;
7076bb2f 1550 vrf_bitmap_unset (zclient->default_information, vrf_id);
0a589359 1551 }
718e3744 1552
1553 if (zclient->sock > 0)
7076bb2f 1554 zebra_message_send (zclient, command, vrf_id);
718e3744 1555}
1556
718e3744 1557static void
1558zclient_event (enum event event, struct zclient *zclient)
1559{
1560 switch (event)
1561 {
1562 case ZCLIENT_SCHEDULE:
1563 if (! zclient->t_connect)
1564 zclient->t_connect =
4140ca4d 1565 thread_add_event (zclient->master, zclient_connect, zclient, 0);
718e3744 1566 break;
1567 case ZCLIENT_CONNECT:
1568 if (zclient->fail >= 10)
1569 return;
1570 if (zclient_debug)
8ddca704 1571 zlog_debug ("zclient connect schedule interval is %d",
718e3744 1572 zclient->fail < 3 ? 10 : 60);
1573 if (! zclient->t_connect)
1574 zclient->t_connect =
4140ca4d 1575 thread_add_timer (zclient->master, zclient_connect, zclient,
718e3744 1576 zclient->fail < 3 ? 10 : 60);
1577 break;
1578 case ZCLIENT_READ:
1579 zclient->t_read =
4140ca4d 1580 thread_add_read (zclient->master, zclient_read, zclient, zclient->sock);
718e3744 1581 break;
1582 }
1583}
b5114685 1584
12e41d03
DL
1585const char *const zclient_serv_path_get()
1586{
1587 return zclient_serv_path ? zclient_serv_path : ZEBRA_SERV_PATH;
1588}
1589
b5114685
VT
1590void
1591zclient_serv_path_set (char *path)
1592{
1593 struct stat sb;
1594
1595 /* reset */
1596 zclient_serv_path = NULL;
1597
1598 /* test if `path' is socket. don't set it otherwise. */
1599 if (stat(path, &sb) == -1)
1600 {
1601 zlog_warn ("%s: zebra socket `%s' does not exist", __func__, path);
1602 return;
1603 }
1604
1605 if ((sb.st_mode & S_IFMT) != S_IFSOCK)
1606 {
1607 zlog_warn ("%s: `%s' is not unix socket, sir", __func__, path);
1608 return;
1609 }
1610
1611 /* it seems that path is unix socket */
1612 zclient_serv_path = path;
1613}
1614