blob: 983969f131ed15eb149ff0a177fccb1e10299c6a [file] [log] [blame]
hassoca776982004-06-12 14:33:05 +00001/*
2 *
3 * Copyright (C) 2000 Robert Olsson.
4 * Swedish University of Agricultural Sciences
5 *
6 * This file is part of GNU Zebra.
7 *
8 * GNU Zebra is free software; you can redistribute it and/or modify it
9 * under the terms of the GNU General Public License as published by the
10 * Free Software Foundation; either version 2, or (at your option) any
11 * later version.
12 *
13 * GNU Zebra is distributed in the hope that it will be useful, but
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with GNU Zebra; see the file COPYING. If not, write to the Free
20 * Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
21 * 02111-1307, USA.
22 */
23
24/*
25 * This work includes work with the following copywrite:
26 *
27 * Copyright (C) 1997, 2000 Kunihiro Ishiguro
28 *
29 */
30
31/*
32 * Thanks to Jens Låås at Swedish University of Agricultural Sciences
33 * for reviewing and tests.
34 */
35
36
37#include <zebra.h>
38
39#ifdef HAVE_IRDP
40
41#include "if.h"
42#include "vty.h"
43#include "sockunion.h"
44#include "prefix.h"
45#include "command.h"
46#include "memory.h"
47#include "stream.h"
48#include "ioctl.h"
49#include "connected.h"
50#include "log.h"
51#include "zclient.h"
52#include "thread.h"
53#include "zebra/interface.h"
54#include "zebra/rtadv.h"
55#include "zebra/rib.h"
56#include "zebra/zserv.h"
57#include "zebra/redistribute.h"
58#include "zebra/irdp.h"
59#include <netinet/ip_icmp.h>
60#include "if.h"
61#include "sockunion.h"
62#include "log.h"
63
64
65/* Master of threads. */
66extern struct zebra_t zebrad;
67
68int in_cksum (void *ptr, int nbytes);
69extern int irdp_sock;
70int irdp_send_thread(struct thread *t_advert);
71char *inet_2a(u_int32_t a, char *b);
72void irdp_advert_off(struct interface *ifp);
73
74
75char b1[16], b2[16], b3[16], b4[16]; /* For inet_2a */
76
77struct prefix *irdp_get_prefix(struct interface *ifp)
78{
paul0c0f9112004-09-24 08:24:42 +000079 struct listnode *node;
hassoca776982004-06-12 14:33:05 +000080 struct connected *ifc;
81
paul0c0f9112004-09-24 08:24:42 +000082 if (ifp->connected)
83 LIST_LOOP (ifp->connected, ifc, node)
hassoca776982004-06-12 14:33:05 +000084 return ifc->address;
paul0c0f9112004-09-24 08:24:42 +000085
hassoca776982004-06-12 14:33:05 +000086 return NULL;
87}
88
89/* Join to the add/leave multicast group. */
90int if_group (struct interface *ifp,
91 int sock,
92 u_int32_t group,
93 int add_leave)
94{
95 struct zebra_if *zi;
96 struct ip_mreq m;
97 struct prefix *p;
98 int ret;
99
100 zi = ifp->info;
101
102 bzero (&m, sizeof (m));
103 m.imr_multiaddr.s_addr = htonl (group);
104 p = irdp_get_prefix(ifp);
105
106 if(!p) {
107 zlog_warn ("IRDP: can't get address for %s", ifp->name);
108 return 1;
109 }
110
111 m.imr_interface = p->u.prefix4;
112
113 ret = setsockopt (sock, IPPROTO_IP, add_leave,
114 (char *) &m, sizeof (struct ip_mreq));
115 if (ret < 0)
116 zlog_warn ("IRDP: %s can't setsockopt %s: %s",
117 add_leave == IP_ADD_MEMBERSHIP? "join group":"leave group",
118 inet_2a(group, b1),
ajs6099b3b2004-11-20 02:06:59 +0000119 safe_strerror (errno));
hassoca776982004-06-12 14:33:05 +0000120
121 return ret;
122}
123
124int if_add_group (struct interface *ifp)
125{
126 struct zebra_if *zi= ifp->info;
127 struct irdp_interface *irdp = &zi->irdp;
128 int ret;
129
130 ret = if_group (ifp, irdp_sock, INADDR_ALLRTRS_GROUP, IP_ADD_MEMBERSHIP);
131 if (ret < 0) {
132 return ret;
133 }
134
135 if(irdp->flags & IF_DEBUG_MISC )
ajsb6178002004-12-07 21:12:56 +0000136 zlog_debug("IRDP: Adding group %s for %s\n",
137 inet_2a(htonl(INADDR_ALLRTRS_GROUP), b1),
138 ifp->name);
hassoca776982004-06-12 14:33:05 +0000139 return 0;
140}
141int if_drop_group (struct interface *ifp)
142{
143 struct zebra_if *zi= ifp->info;
144 struct irdp_interface *irdp = &zi->irdp;
145 int ret;
146
147 ret = if_group (ifp, irdp_sock, INADDR_ALLRTRS_GROUP, IP_DROP_MEMBERSHIP);
148 if (ret < 0)
149 return ret;
150
151 if(irdp->flags & IF_DEBUG_MISC)
ajsb6178002004-12-07 21:12:56 +0000152 zlog_debug("IRDP: Leaving group %s for %s\n",
153 inet_2a(htonl(INADDR_ALLRTRS_GROUP), b1),
154 ifp->name);
hassoca776982004-06-12 14:33:05 +0000155 return 0;
156}
157
hasso39db97e2004-10-12 20:50:58 +0000158struct interface *get_iflist_ifp(unsigned int idx)
hassoca776982004-06-12 14:33:05 +0000159{
paul0c0f9112004-09-24 08:24:42 +0000160 struct listnode *node;
hassoca776982004-06-12 14:33:05 +0000161 struct interface *ifp;
162
paul0c0f9112004-09-24 08:24:42 +0000163 LIST_LOOP (iflist, ifp, node)
164 if(ifp->ifindex == idx)
165 return ifp;
166
hassoca776982004-06-12 14:33:05 +0000167 return NULL;
168}
169
170void
171if_set_defaults(struct interface *ifp)
172{
173 struct zebra_if *zi=ifp->info;
174 struct irdp_interface *irdp=&zi->irdp;
175
176 irdp->MaxAdvertInterval = IRDP_MAXADVERTINTERVAL;
177 irdp->MinAdvertInterval = IRDP_MINADVERTINTERVAL;
178 irdp->Preference = IRDP_PREFERENCE;
179 irdp->Lifetime = IRDP_LIFETIME;
180}
181
182
183struct Adv *Adv_new ()
184{
185 struct Adv *new;
186 new = XMALLOC (MTYPE_TMP, sizeof (struct Adv));
187 memset (new, 0, sizeof (struct Adv));
188 return new;
189}
190
191void Adv_free (struct Adv *adv)
192{
193 XFREE (MTYPE_TMP, adv);
194}
195
196void irdp_if_start(struct interface *ifp, int multicast, int set_defaults)
197{
198 struct zebra_if *zi= ifp->info;
199 struct irdp_interface *irdp = &zi->irdp;
paul0c0f9112004-09-24 08:24:42 +0000200 struct listnode *node;
201 struct connected *ifc;
hassoca776982004-06-12 14:33:05 +0000202 u_int32_t timer, seed;
203
204 if (irdp->flags & IF_ACTIVE ) {
205 zlog_warn("IRDP: Interface is already active %s\n", ifp->name);
206 return;
207 }
208 irdp->flags |= IF_ACTIVE;
209
210 if(!multicast)
211 irdp->flags |= IF_BROADCAST;
212
213 if_add_update(ifp);
214
215 if (! (ifp->flags & IFF_UP)) {
216 zlog_warn("IRDP: Interface is down %s\n", ifp->name);
217 }
218
219 /* Shall we cancel if_start if if_add_group fails? */
220
221 if( multicast) {
222 if_add_group(ifp);
223
224 if (! (ifp->flags & (IFF_MULTICAST|IFF_ALLMULTI))) {
225 zlog_warn("IRDP: Interface not multicast enabled %s\n", ifp->name);
226 }
227 }
228
229 if(set_defaults)
230 if_set_defaults(ifp);
231
232 irdp->irdp_sent = 0;
233
234 /* The spec suggests this for randomness */
235
236 seed = 0;
paul0c0f9112004-09-24 08:24:42 +0000237 if( ifp->connected)
238 LIST_LOOP (ifp->connected, ifc, node)
239 {
240 seed = ifc->address->u.prefix4.s_addr;
241 break;
242 }
hassoca776982004-06-12 14:33:05 +0000243
244 srandom(seed);
245 timer = (random () % IRDP_DEFAULT_INTERVAL) + 1;
246
247 irdp->AdvPrefList = list_new();
hassoc9e52be2004-09-26 16:09:34 +0000248 irdp->AdvPrefList->del = (void (*)(void *)) Adv_free; /* Destructor */
hassoca776982004-06-12 14:33:05 +0000249
250
251 /* And this for startup. Speed limit from 1991 :-). But it's OK*/
252
253 if(irdp->irdp_sent < MAX_INITIAL_ADVERTISEMENTS &&
254 timer > MAX_INITIAL_ADVERT_INTERVAL )
255 timer= MAX_INITIAL_ADVERT_INTERVAL;
256
257
258 if(irdp->flags & IF_DEBUG_MISC)
ajsb6178002004-12-07 21:12:56 +0000259 zlog_debug("IRDP: Init timer for %s set to %u\n",
260 ifp->name,
261 timer);
hassoca776982004-06-12 14:33:05 +0000262
263 irdp->t_advertise = thread_add_timer(zebrad.master,
264 irdp_send_thread,
265 ifp,
266 timer);
267}
268
269void irdp_if_stop(struct interface *ifp)
270{
271 struct zebra_if *zi=ifp->info;
272 struct irdp_interface *irdp=&zi->irdp;
273
274 if (irdp == NULL) {
275 zlog_warn ("Interface %s structure is NULL", ifp->name);
276 return;
277 }
278
279 if (! (irdp->flags & IF_ACTIVE )) {
280 zlog_warn("Interface is not active %s\n", ifp->name);
281 return;
282 }
283
284 if(! (irdp->flags & IF_BROADCAST))
285 if_drop_group(ifp);
286
287 irdp_advert_off(ifp);
288
289 list_delete(irdp->AdvPrefList);
290 irdp->AdvPrefList=NULL;
291
292 irdp->flags = 0;
293}
294
295
296void irdp_if_shutdown(struct interface *ifp)
297{
298 struct zebra_if *zi= ifp->info;
299 struct irdp_interface *irdp = &zi->irdp;
300
301 if (irdp->flags & IF_SHUTDOWN ) {
302 zlog_warn("IRDP: Interface is already shutdown %s\n", ifp->name);
303 return;
304 }
305
306 irdp->flags |= IF_SHUTDOWN;
307 irdp->flags &= ~IF_ACTIVE;
308
309 if(! (irdp->flags & IF_BROADCAST))
310 if_drop_group(ifp);
311
312 /* Tell the hosts we are out of service */
313 irdp_advert_off(ifp);
314}
315
316void irdp_if_no_shutdown(struct interface *ifp)
317{
318 struct zebra_if *zi= ifp->info;
319 struct irdp_interface *irdp = &zi->irdp;
320
321 if (! (irdp->flags & IF_SHUTDOWN )) {
322 zlog_warn("IRDP: Interface is not shutdown %s\n", ifp->name);
323 return;
324 }
325
326 irdp->flags &= ~IF_SHUTDOWN;
327
328 irdp_if_start(ifp, irdp->flags & IF_BROADCAST? FALSE : TRUE, FALSE);
329
330}
331
332
333/* Write configuration to user */
334
335void irdp_config_write (struct vty *vty, struct interface *ifp)
336{
337 struct zebra_if *zi=ifp->info;
338 struct irdp_interface *irdp=&zi->irdp;
339 struct Adv *adv;
paul0c0f9112004-09-24 08:24:42 +0000340 struct listnode *node;
hassoca776982004-06-12 14:33:05 +0000341
342 if(irdp->flags & IF_ACTIVE || irdp->flags & IF_SHUTDOWN) {
343
344 if( irdp->flags & IF_SHUTDOWN)
345 vty_out (vty, " ip irdp shutdown %s", VTY_NEWLINE);
346
347 if( irdp->flags & IF_BROADCAST)
348 vty_out (vty, " ip irdp broadcast%s", VTY_NEWLINE);
349 else
350 vty_out (vty, " ip irdp multicast%s", VTY_NEWLINE);
351
352 vty_out (vty, " ip irdp preference %ld%s",
353 irdp->Preference, VTY_NEWLINE);
354
paul0c0f9112004-09-24 08:24:42 +0000355 LIST_LOOP (irdp->AdvPrefList, adv, node)
356 vty_out (vty, " ip irdp address %s preference %d%s",
357 inet_2a(adv->ip.s_addr, b1),
358 adv->pref,
359 VTY_NEWLINE);
hassoca776982004-06-12 14:33:05 +0000360
361 vty_out (vty, " ip irdp holdtime %d%s",
362 irdp->Lifetime, VTY_NEWLINE);
363
364 vty_out (vty, " ip irdp minadvertinterval %ld%s",
365 irdp->MinAdvertInterval, VTY_NEWLINE);
366
367 vty_out (vty, " ip irdp maxadvertinterval %ld%s",
368 irdp->MaxAdvertInterval, VTY_NEWLINE);
369
370 }
371}
372
373
374DEFUN (ip_irdp_multicast,
375 ip_irdp_multicast_cmd,
376 "ip irdp multicast",
377 IP_STR
378 "ICMP Router discovery on this interface using multicast\n")
379{
380 struct interface *ifp;
381
382 ifp = (struct interface *) vty->index;
383 if(!ifp) {
384 return CMD_WARNING;
385 }
386
387 irdp_if_start(ifp, TRUE, TRUE);
388 return CMD_SUCCESS;
389}
390
391DEFUN (ip_irdp_broadcast,
392 ip_irdp_broadcast_cmd,
393 "ip irdp broadcast",
394 IP_STR
395 "ICMP Router discovery on this interface using broadcast\n")
396{
397 struct interface *ifp;
398
399 ifp = (struct interface *) vty->index;
400 if(!ifp) {
401 return CMD_WARNING;
402 }
403
404 irdp_if_start(ifp, FALSE, TRUE);
405 return CMD_SUCCESS;
406}
407
hasso996933f2004-07-12 16:32:56 +0000408DEFUN (no_ip_irdp,
409 no_ip_irdp_cmd,
hassoca776982004-06-12 14:33:05 +0000410 "no ip irdp",
hasso8d0f15f2004-09-11 16:33:28 +0000411 NO_STR
hassoca776982004-06-12 14:33:05 +0000412 IP_STR
413 "Disable ICMP Router discovery on this interface\n")
414{
415 struct interface *ifp;
416
417 ifp = (struct interface *) vty->index;
418 if(!ifp) {
419 return CMD_WARNING;
420 }
421
422 irdp_if_stop(ifp);
423 return CMD_SUCCESS;
424}
425
426DEFUN (ip_irdp_shutdown,
427 ip_irdp_shutdown_cmd,
428 "ip irdp shutdown",
429 IP_STR
430 "ICMP Router discovery shutdown on this interface\n")
431{
432 struct interface *ifp;
433
434 ifp = (struct interface *) vty->index;
435 if(!ifp) {
436 return CMD_WARNING;
437 }
438
439 irdp_if_shutdown(ifp);
440 return CMD_SUCCESS;
441}
442
hasso996933f2004-07-12 16:32:56 +0000443DEFUN (no_ip_irdp_shutdown,
444 no_ip_irdp_shutdown_cmd,
hassoca776982004-06-12 14:33:05 +0000445 "no ip irdp shutdown",
hasso8d0f15f2004-09-11 16:33:28 +0000446 NO_STR
hassoca776982004-06-12 14:33:05 +0000447 IP_STR
448 "ICMP Router discovery no shutdown on this interface\n")
449{
450 struct interface *ifp;
451
452 ifp = (struct interface *) vty->index;
453 if(!ifp) {
454 return CMD_WARNING;
455 }
456
457 irdp_if_no_shutdown(ifp);
458 return CMD_SUCCESS;
459}
460
461DEFUN (ip_irdp_holdtime,
462 ip_irdp_holdtime_cmd,
463 "ip irdp holdtime <0-9000>",
464 IP_STR
465 "ICMP Router discovery on this interface\n"
466 "Set holdtime value\n"
467 "Holdtime value in seconds. Default is 1800 seconds\n")
468{
469 struct interface *ifp;
470 struct zebra_if *zi;
471 struct irdp_interface *irdp;
472 ifp = (struct interface *) vty->index;
473 if(!ifp) {
474 return CMD_WARNING;
475 }
476
477 zi=ifp->info;
478 irdp=&zi->irdp;
479
480 irdp->Lifetime = atoi(argv[0]);
481 return CMD_SUCCESS;
482}
483
484DEFUN (ip_irdp_minadvertinterval,
485 ip_irdp_minadvertinterval_cmd,
486 "ip irdp minadvertinterval <3-1800>",
487 IP_STR
488 "ICMP Router discovery on this interface\n"
489 "Set minimum time between advertisement\n"
490 "Minimum advertisement interval in seconds\n")
491{
492 struct interface *ifp;
493 struct zebra_if *zi;
494 struct irdp_interface *irdp;
495 ifp = (struct interface *) vty->index;
496 if(!ifp) {
497 return CMD_WARNING;
498 }
499
500 zi=ifp->info;
501 irdp=&zi->irdp;
502
hasso39db97e2004-10-12 20:50:58 +0000503 if( (unsigned) atoi(argv[0]) <= irdp->MaxAdvertInterval) {
hassoca776982004-06-12 14:33:05 +0000504 irdp->MinAdvertInterval = atoi(argv[0]);
505
506 return CMD_SUCCESS;
507 }
508
509 vty_out (vty, "ICMP warning maxadvertinterval is greater or equal than minadvertinterval%s",
510 VTY_NEWLINE);
511
512 vty_out (vty, "Please correct!%s",
513 VTY_NEWLINE);
514 return CMD_WARNING;
515}
516
517DEFUN (ip_irdp_maxadvertinterval,
518 ip_irdp_maxadvertinterval_cmd,
519 "ip irdp maxadvertinterval <4-1800>",
520 IP_STR
521 "ICMP Router discovery on this interface\n"
522 "Set maximum time between advertisement\n"
523 "Maximum advertisement interval in seconds\n")
524{
525 struct interface *ifp;
526 struct zebra_if *zi;
527 struct irdp_interface *irdp;
528 ifp = (struct interface *) vty->index;
529 if(!ifp) {
530 return CMD_WARNING;
531 }
532
533 zi=ifp->info;
534 irdp=&zi->irdp;
535
536
hasso39db97e2004-10-12 20:50:58 +0000537 if( irdp->MinAdvertInterval <= (unsigned) atoi(argv[0]) ) {
hassoca776982004-06-12 14:33:05 +0000538 irdp->MaxAdvertInterval = atoi(argv[0]);
539
540 return CMD_SUCCESS;
541 }
542
543 vty_out (vty, "ICMP warning maxadvertinterval is greater or equal than minadvertinterval%s",
544 VTY_NEWLINE);
545
546 vty_out (vty, "Please correct!%s",
547 VTY_NEWLINE);
548 return CMD_WARNING;
549}
550
hassoaccb1562004-11-25 19:21:07 +0000551/* DEFUN needs to be fixed for negative ranages...
552 * "ip irdp preference <-2147483648-2147483647>",
553 * Be positive for now. :-)
554 */
555
hassoca776982004-06-12 14:33:05 +0000556DEFUN (ip_irdp_preference,
557 ip_irdp_preference_cmd,
hassoca776982004-06-12 14:33:05 +0000558 "ip irdp preference <0-2147483647>",
559 IP_STR
560 "ICMP Router discovery on this interface\n"
561 "Set default preference level for this interface\n"
562 "Preference level\n")
563{
564 struct interface *ifp;
565 struct zebra_if *zi;
566 struct irdp_interface *irdp;
567 ifp = (struct interface *) vty->index;
568 if(!ifp) {
569 return CMD_WARNING;
570 }
571
572 zi=ifp->info;
573 irdp=&zi->irdp;
574
575 irdp->Preference = atoi(argv[0]);
576 return CMD_SUCCESS;
577}
578
579DEFUN (ip_irdp_address_preference,
580 ip_irdp_address_preference_cmd,
581 "ip irdp address A.B.C.D preference <0-2147483647>",
582 IP_STR
583 "Alter ICMP Router discovery preference this interface\n"
584 "Specify IRDP non-default preference to advertise\n"
585 "Set IRDP address for advertise\n"
586 "Preference level\n")
587{
paul0c0f9112004-09-24 08:24:42 +0000588 struct listnode *node;
hassoca776982004-06-12 14:33:05 +0000589 struct in_addr ip;
590 int pref;
591 int ret;
592 struct interface *ifp;
593 struct zebra_if *zi;
594 struct irdp_interface *irdp;
595 struct Adv *adv;
596
597 ifp = (struct interface *) vty->index;
598 if(!ifp) {
599 return CMD_WARNING;
600 }
601
602 zi=ifp->info;
603 irdp=&zi->irdp;
604
605 ret = inet_aton(argv[0], &ip);
606 if(!ret) return CMD_WARNING;
607
608 pref = atoi(argv[1]);
609
paul0c0f9112004-09-24 08:24:42 +0000610 LIST_LOOP (irdp->AdvPrefList, adv, node)
611 if(adv->ip.s_addr == ip.s_addr)
612 return CMD_SUCCESS;
hassoca776982004-06-12 14:33:05 +0000613
614 adv = Adv_new();
615 adv->ip = ip;
616 adv->pref = pref;
617 listnode_add(irdp->AdvPrefList, adv);
618
619 return CMD_SUCCESS;
620
621}
622
hasso996933f2004-07-12 16:32:56 +0000623DEFUN (no_ip_irdp_address_preference,
624 no_ip_irdp_address_preference_cmd,
hassoca776982004-06-12 14:33:05 +0000625 "no ip irdp address A.B.C.D preference <0-2147483647>",
hasso8d0f15f2004-09-11 16:33:28 +0000626 NO_STR
hassoca776982004-06-12 14:33:05 +0000627 IP_STR
628 "Alter ICMP Router discovery preference this interface\n"
629 "Removes IRDP non-default preference\n"
630 "Select IRDP address\n"
631 "Old preference level\n")
632{
paul26f7a242004-09-24 08:45:10 +0000633 struct listnode *node, *nnode;
hassoca776982004-06-12 14:33:05 +0000634 struct in_addr ip;
635 int pref;
636 int ret;
637 struct interface *ifp;
638 struct zebra_if *zi;
639 struct irdp_interface *irdp;
640 struct Adv *adv;
641
642 ifp = (struct interface *) vty->index;
643 if(!ifp) {
644 return CMD_WARNING;
645 }
646
647 zi=ifp->info;
648 irdp=&zi->irdp;
649
650 ret = inet_aton(argv[0], &ip);
paul0c0f9112004-09-24 08:24:42 +0000651 if (!ret)
652 return CMD_WARNING;
hassoca776982004-06-12 14:33:05 +0000653
654 pref = atoi(argv[1]);
655
paul0c0f9112004-09-24 08:24:42 +0000656 for (node = listhead (irdp->AdvPrefList); node; node = nnode)
657 {
658 nnode = node->next;
659 adv = getdata (node);
660
661 if(adv->ip.s_addr == ip.s_addr )
662 {
663 listnode_delete(irdp->AdvPrefList, adv);
664 break;
665 }
666 }
667
hassoca776982004-06-12 14:33:05 +0000668 return CMD_SUCCESS;
hassoca776982004-06-12 14:33:05 +0000669}
670
671DEFUN (ip_irdp_debug_messages,
672 ip_irdp_debug_messages_cmd,
673 "ip irdp debug messages",
674 IP_STR
675 "ICMP Router discovery debug Averts. and Solicits (short)\n")
676{
677 struct interface *ifp;
678 struct zebra_if *zi;
679 struct irdp_interface *irdp;
680 ifp = (struct interface *) vty->index;
681 if(!ifp) {
682 return CMD_WARNING;
683 }
684
685 zi=ifp->info;
686 irdp=&zi->irdp;
687
688 irdp->flags |= IF_DEBUG_MESSAGES;
689
690 return CMD_SUCCESS;
691}
692
693DEFUN (ip_irdp_debug_misc,
694 ip_irdp_debug_misc_cmd,
695 "ip irdp debug misc",
696 IP_STR
697 "ICMP Router discovery debug Averts. and Solicits (short)\n")
698{
699 struct interface *ifp;
700 struct zebra_if *zi;
701 struct irdp_interface *irdp;
702 ifp = (struct interface *) vty->index;
703 if(!ifp) {
704 return CMD_WARNING;
705 }
706
707 zi=ifp->info;
708 irdp=&zi->irdp;
709
710 irdp->flags |= IF_DEBUG_MISC;
711
712 return CMD_SUCCESS;
713}
714
715DEFUN (ip_irdp_debug_packet,
716 ip_irdp_debug_packet_cmd,
717 "ip irdp debug packet",
718 IP_STR
719 "ICMP Router discovery debug Averts. and Solicits (short)\n")
720{
721 struct interface *ifp;
722 struct zebra_if *zi;
723 struct irdp_interface *irdp;
724 ifp = (struct interface *) vty->index;
725 if(!ifp) {
726 return CMD_WARNING;
727 }
728
729 zi=ifp->info;
730 irdp=&zi->irdp;
731
732 irdp->flags |= IF_DEBUG_PACKET;
733
734 return CMD_SUCCESS;
735}
736
737
738DEFUN (ip_irdp_debug_disable,
739 ip_irdp_debug_disable_cmd,
740 "ip irdp debug disable",
741 IP_STR
742 "ICMP Router discovery debug Averts. and Solicits (short)\n")
743{
744 struct interface *ifp;
745 struct zebra_if *zi;
746 struct irdp_interface *irdp;
747 ifp = (struct interface *) vty->index;
748 if(!ifp) {
749 return CMD_WARNING;
750 }
751
752 zi=ifp->info;
753 irdp=&zi->irdp;
754
755 irdp->flags &= ~IF_DEBUG_PACKET;
756 irdp->flags &= ~IF_DEBUG_MESSAGES;
757 irdp->flags &= ~IF_DEBUG_MISC;
758
759 return CMD_SUCCESS;
760}
761
762void
763irdp_if_init ()
764{
765 install_element (INTERFACE_NODE, &ip_irdp_broadcast_cmd);
766 install_element (INTERFACE_NODE, &ip_irdp_multicast_cmd);
hasso996933f2004-07-12 16:32:56 +0000767 install_element (INTERFACE_NODE, &no_ip_irdp_cmd);
hassoca776982004-06-12 14:33:05 +0000768 install_element (INTERFACE_NODE, &ip_irdp_shutdown_cmd);
hasso996933f2004-07-12 16:32:56 +0000769 install_element (INTERFACE_NODE, &no_ip_irdp_shutdown_cmd);
hassoca776982004-06-12 14:33:05 +0000770 install_element (INTERFACE_NODE, &ip_irdp_holdtime_cmd);
771 install_element (INTERFACE_NODE, &ip_irdp_maxadvertinterval_cmd);
772 install_element (INTERFACE_NODE, &ip_irdp_minadvertinterval_cmd);
773 install_element (INTERFACE_NODE, &ip_irdp_preference_cmd);
774 install_element (INTERFACE_NODE, &ip_irdp_address_preference_cmd);
hasso996933f2004-07-12 16:32:56 +0000775 install_element (INTERFACE_NODE, &no_ip_irdp_address_preference_cmd);
hassoca776982004-06-12 14:33:05 +0000776
777 install_element (INTERFACE_NODE, &ip_irdp_debug_messages_cmd);
778 install_element (INTERFACE_NODE, &ip_irdp_debug_misc_cmd);
779 install_element (INTERFACE_NODE, &ip_irdp_debug_packet_cmd);
780 install_element (INTERFACE_NODE, &ip_irdp_debug_disable_cmd);
781}
782
783#endif /* HAVE_IRDP */