]> git.proxmox.com Git - mirror_frr.git/blame - bgpd/bgp_route.c
lib: Fix accounting of memory
[mirror_frr.git] / bgpd / bgp_route.c
CommitLineData
718e3744 1/* BGP routing information
2 Copyright (C) 1996, 97, 98, 99 Kunihiro Ishiguro
3
4This file is part of GNU Zebra.
5
6GNU Zebra is free software; you can redistribute it and/or modify it
7under the terms of the GNU General Public License as published by the
8Free Software Foundation; either version 2, or (at your option) any
9later version.
10
11GNU Zebra is distributed in the hope that it will be useful, but
12WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14General Public License for more details.
15
16You should have received a copy of the GNU General Public License
17along with GNU Zebra; see the file COPYING. If not, write to the Free
18Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
1902111-1307, USA. */
20
21#include <zebra.h>
22
23#include "prefix.h"
24#include "linklist.h"
25#include "memory.h"
26#include "command.h"
27#include "stream.h"
28#include "filter.h"
29#include "str.h"
30#include "log.h"
31#include "routemap.h"
32#include "buffer.h"
33#include "sockunion.h"
34#include "plist.h"
35#include "thread.h"
200df115 36#include "workqueue.h"
718e3744 37
38#include "bgpd/bgpd.h"
39#include "bgpd/bgp_table.h"
40#include "bgpd/bgp_route.h"
41#include "bgpd/bgp_attr.h"
42#include "bgpd/bgp_debug.h"
43#include "bgpd/bgp_aspath.h"
44#include "bgpd/bgp_regex.h"
45#include "bgpd/bgp_community.h"
46#include "bgpd/bgp_ecommunity.h"
47#include "bgpd/bgp_clist.h"
48#include "bgpd/bgp_packet.h"
49#include "bgpd/bgp_filter.h"
50#include "bgpd/bgp_fsm.h"
51#include "bgpd/bgp_mplsvpn.h"
52#include "bgpd/bgp_nexthop.h"
53#include "bgpd/bgp_damp.h"
54#include "bgpd/bgp_advertise.h"
55#include "bgpd/bgp_zebra.h"
0a486e5f 56#include "bgpd/bgp_vty.h"
718e3744 57
58/* Extern from bgp_dump.c */
dde72586
SH
59extern const char *bgp_origin_str[];
60extern const char *bgp_origin_long_str[];
718e3744 61\f
94f2b392 62static struct bgp_node *
fee0f4c6 63bgp_afi_node_get (struct bgp_table *table, afi_t afi, safi_t safi, struct prefix *p,
718e3744 64 struct prefix_rd *prd)
65{
66 struct bgp_node *rn;
67 struct bgp_node *prn = NULL;
da5b30f6
PJ
68
69 assert (table);
70 if (!table)
71 return NULL;
72
718e3744 73 if (safi == SAFI_MPLS_VPN)
74 {
fee0f4c6 75 prn = bgp_node_get (table, (struct prefix *) prd);
718e3744 76
77 if (prn->info == NULL)
64e580a7 78 prn->info = bgp_table_init (afi, safi);
718e3744 79 else
80 bgp_unlock_node (prn);
81 table = prn->info;
82 }
718e3744 83
84 rn = bgp_node_get (table, p);
85
86 if (safi == SAFI_MPLS_VPN)
87 rn->prn = prn;
88
89 return rn;
90}
91\f
fb982c25
PJ
92/* Allocate bgp_info_extra */
93static struct bgp_info_extra *
94bgp_info_extra_new (void)
95{
96 struct bgp_info_extra *new;
97 new = XCALLOC (MTYPE_BGP_ROUTE_EXTRA, sizeof (struct bgp_info_extra));
98 return new;
99}
100
101static void
102bgp_info_extra_free (struct bgp_info_extra **extra)
103{
104 if (extra && *extra)
105 {
106 if ((*extra)->damp_info)
107 bgp_damp_info_free ((*extra)->damp_info, 0);
108
109 (*extra)->damp_info = NULL;
110
111 XFREE (MTYPE_BGP_ROUTE_EXTRA, *extra);
112
113 *extra = NULL;
114 }
115}
116
117/* Get bgp_info extra information for the given bgp_info, lazy allocated
118 * if required.
119 */
120struct bgp_info_extra *
121bgp_info_extra_get (struct bgp_info *ri)
122{
123 if (!ri->extra)
124 ri->extra = bgp_info_extra_new();
125 return ri->extra;
126}
127
718e3744 128/* Allocate new bgp info structure. */
200df115 129static struct bgp_info *
66e5cd87 130bgp_info_new (void)
718e3744 131{
393deb9b 132 return XCALLOC (MTYPE_BGP_ROUTE, sizeof (struct bgp_info));
718e3744 133}
134
135/* Free bgp route information. */
200df115 136static void
718e3744 137bgp_info_free (struct bgp_info *binfo)
138{
139 if (binfo->attr)
140 bgp_attr_unintern (binfo->attr);
fb982c25
PJ
141
142 bgp_info_extra_free (&binfo->extra);
718e3744 143
200df115 144 peer_unlock (binfo->peer); /* bgp_info peer reference */
145
718e3744 146 XFREE (MTYPE_BGP_ROUTE, binfo);
147}
148
200df115 149struct bgp_info *
150bgp_info_lock (struct bgp_info *binfo)
151{
152 binfo->lock++;
153 return binfo;
154}
155
156struct bgp_info *
157bgp_info_unlock (struct bgp_info *binfo)
158{
159 assert (binfo && binfo->lock > 0);
160 binfo->lock--;
161
162 if (binfo->lock == 0)
163 {
164#if 0
165 zlog_debug ("%s: unlocked and freeing", __func__);
166 zlog_backtrace (LOG_DEBUG);
167#endif
168 bgp_info_free (binfo);
169 return NULL;
170 }
171
172#if 0
173 if (binfo->lock == 1)
174 {
175 zlog_debug ("%s: unlocked to 1", __func__);
176 zlog_backtrace (LOG_DEBUG);
177 }
178#endif
179
180 return binfo;
181}
182
718e3744 183void
184bgp_info_add (struct bgp_node *rn, struct bgp_info *ri)
185{
186 struct bgp_info *top;
187
188 top = rn->info;
200df115 189
718e3744 190 ri->next = rn->info;
191 ri->prev = NULL;
192 if (top)
193 top->prev = ri;
194 rn->info = ri;
200df115 195
196 bgp_info_lock (ri);
197 bgp_lock_node (rn);
198 peer_lock (ri->peer); /* bgp_info peer reference */
718e3744 199}
200
b40d939b 201/* Do the actual removal of info from RIB, for use by bgp_process
202 completion callback *only* */
203static void
204bgp_info_reap (struct bgp_node *rn, struct bgp_info *ri)
718e3744 205{
206 if (ri->next)
207 ri->next->prev = ri->prev;
208 if (ri->prev)
209 ri->prev->next = ri->next;
210 else
211 rn->info = ri->next;
200df115 212
213 bgp_info_unlock (ri);
214 bgp_unlock_node (rn);
718e3744 215}
216
b40d939b 217void
218bgp_info_delete (struct bgp_node *rn, struct bgp_info *ri)
219{
1a392d46
PJ
220 bgp_info_set_flag (rn, ri, BGP_INFO_REMOVED);
221 /* set of previous already took care of pcount */
b40d939b 222 UNSET_FLAG (ri->flags, BGP_INFO_VALID);
223}
224
8d45210e
AS
225/* undo the effects of a previous call to bgp_info_delete; typically
226 called when a route is deleted and then quickly re-added before the
227 deletion has been processed */
228static void
229bgp_info_restore (struct bgp_node *rn, struct bgp_info *ri)
230{
231 bgp_info_unset_flag (rn, ri, BGP_INFO_REMOVED);
232 /* unset of previous already took care of pcount */
233 SET_FLAG (ri->flags, BGP_INFO_VALID);
234}
235
1a392d46
PJ
236/* Adjust pcount as required */
237static void
238bgp_pcount_adjust (struct bgp_node *rn, struct bgp_info *ri)
239{
6f58544d
PJ
240 assert (rn && rn->table);
241 assert (ri && ri->peer && ri->peer->bgp);
242
1a392d46
PJ
243 /* Ignore 'pcount' for RS-client tables */
244 if (rn->table->type != BGP_TABLE_MAIN
245 || ri->peer == ri->peer->bgp->peer_self)
246 return;
247
248 if (BGP_INFO_HOLDDOWN (ri)
249 && CHECK_FLAG (ri->flags, BGP_INFO_COUNTED))
250 {
251
252 UNSET_FLAG (ri->flags, BGP_INFO_COUNTED);
253
254 /* slight hack, but more robust against errors. */
255 if (ri->peer->pcount[rn->table->afi][rn->table->safi])
256 ri->peer->pcount[rn->table->afi][rn->table->safi]--;
257 else
258 {
259 zlog_warn ("%s: Asked to decrement 0 prefix count for peer %s",
260 __func__, ri->peer->host);
261 zlog_backtrace (LOG_WARNING);
262 zlog_warn ("%s: Please report to Quagga bugzilla", __func__);
263 }
264 }
265 else if (!BGP_INFO_HOLDDOWN (ri)
266 && !CHECK_FLAG (ri->flags, BGP_INFO_COUNTED))
267 {
268 SET_FLAG (ri->flags, BGP_INFO_COUNTED);
269 ri->peer->pcount[rn->table->afi][rn->table->safi]++;
270 }
271}
272
273
274/* Set/unset bgp_info flags, adjusting any other state as needed.
275 * This is here primarily to keep prefix-count in check.
276 */
277void
278bgp_info_set_flag (struct bgp_node *rn, struct bgp_info *ri, u_int32_t flag)
279{
280 SET_FLAG (ri->flags, flag);
281
282 /* early bath if we know it's not a flag that changes useability state */
283 if (!CHECK_FLAG (flag, BGP_INFO_VALID|BGP_INFO_UNUSEABLE))
284 return;
285
286 bgp_pcount_adjust (rn, ri);
287}
288
289void
290bgp_info_unset_flag (struct bgp_node *rn, struct bgp_info *ri, u_int32_t flag)
291{
292 UNSET_FLAG (ri->flags, flag);
293
294 /* early bath if we know it's not a flag that changes useability state */
295 if (!CHECK_FLAG (flag, BGP_INFO_VALID|BGP_INFO_UNUSEABLE))
296 return;
297
298 bgp_pcount_adjust (rn, ri);
299}
300
718e3744 301/* Get MED value. If MED value is missing and "bgp bestpath
302 missing-as-worst" is specified, treat it as the worst value. */
94f2b392 303static u_int32_t
718e3744 304bgp_med_value (struct attr *attr, struct bgp *bgp)
305{
306 if (attr->flag & ATTR_FLAG_BIT (BGP_ATTR_MULTI_EXIT_DISC))
307 return attr->med;
308 else
309 {
310 if (bgp_flag_check (bgp, BGP_FLAG_MED_MISSING_AS_WORST))
3b424979 311 return BGP_MED_MAX;
718e3744 312 else
313 return 0;
314 }
315}
316
317/* Compare two bgp route entity. br is preferable then return 1. */
94f2b392 318static int
718e3744 319bgp_info_cmp (struct bgp *bgp, struct bgp_info *new, struct bgp_info *exist)
320{
321 u_int32_t new_pref;
322 u_int32_t exist_pref;
323 u_int32_t new_med;
324 u_int32_t exist_med;
fb982c25
PJ
325 u_int32_t new_weight = 0;
326 u_int32_t exist_weight = 0;
718e3744 327 struct in_addr new_id;
328 struct in_addr exist_id;
329 int new_cluster;
330 int exist_cluster;
331 int internal_as_route = 0;
332 int confed_as_route = 0;
333 int ret;
334
335 /* 0. Null check. */
336 if (new == NULL)
337 return 0;
338 if (exist == NULL)
339 return 1;
340
341 /* 1. Weight check. */
fb982c25
PJ
342 if (new->attr->extra)
343 new_weight = new->attr->extra->weight;
344 if (exist->attr->extra)
345 exist_weight = exist->attr->extra->weight;
346 if (new_weight > exist_weight)
718e3744 347 return 1;
fb982c25 348 if (new_weight < exist_weight)
718e3744 349 return 0;
350
351 /* 2. Local preference check. */
352 if (new->attr->flag & ATTR_FLAG_BIT (BGP_ATTR_LOCAL_PREF))
353 new_pref = new->attr->local_pref;
354 else
355 new_pref = bgp->default_local_pref;
356
357 if (exist->attr->flag & ATTR_FLAG_BIT (BGP_ATTR_LOCAL_PREF))
358 exist_pref = exist->attr->local_pref;
359 else
360 exist_pref = bgp->default_local_pref;
361
362 if (new_pref > exist_pref)
363 return 1;
364 if (new_pref < exist_pref)
365 return 0;
366
367 /* 3. Local route check. */
368 if (new->sub_type == BGP_ROUTE_STATIC)
369 return 1;
370 if (exist->sub_type == BGP_ROUTE_STATIC)
371 return 0;
372
373 if (new->sub_type == BGP_ROUTE_REDISTRIBUTE)
374 return 1;
375 if (exist->sub_type == BGP_ROUTE_REDISTRIBUTE)
376 return 0;
377
378 if (new->sub_type == BGP_ROUTE_AGGREGATE)
379 return 1;
380 if (exist->sub_type == BGP_ROUTE_AGGREGATE)
381 return 0;
382
383 /* 4. AS path length check. */
384 if (! bgp_flag_check (bgp, BGP_FLAG_ASPATH_IGNORE))
385 {
fe69a505 386 int exist_hops = aspath_count_hops (exist->attr->aspath);
387 int exist_confeds = aspath_count_confeds (exist->attr->aspath);
388
6811845b 389 if (bgp_flag_check (bgp, BGP_FLAG_ASPATH_CONFED))
390 {
fe69a505 391 int aspath_hops;
392
393 aspath_hops = aspath_count_hops (new->attr->aspath);
394 aspath_hops += aspath_count_confeds (new->attr->aspath);
395
396 if ( aspath_hops < (exist_hops + exist_confeds))
6811845b 397 return 1;
fe69a505 398 if ( aspath_hops > (exist_hops + exist_confeds))
6811845b 399 return 0;
400 }
401 else
402 {
fe69a505 403 int newhops = aspath_count_hops (new->attr->aspath);
404
405 if (newhops < exist_hops)
6811845b 406 return 1;
fe69a505 407 if (newhops > exist_hops)
6811845b 408 return 0;
409 }
718e3744 410 }
411
412 /* 5. Origin check. */
413 if (new->attr->origin < exist->attr->origin)
414 return 1;
415 if (new->attr->origin > exist->attr->origin)
416 return 0;
417
418 /* 6. MED check. */
fe69a505 419 internal_as_route = (aspath_count_hops (new->attr->aspath) == 0
420 && aspath_count_hops (exist->attr->aspath) == 0);
421 confed_as_route = (aspath_count_confeds (new->attr->aspath) > 0
422 && aspath_count_confeds (exist->attr->aspath) > 0
423 && aspath_count_hops (new->attr->aspath) == 0
424 && aspath_count_hops (exist->attr->aspath) == 0);
718e3744 425
426 if (bgp_flag_check (bgp, BGP_FLAG_ALWAYS_COMPARE_MED)
427 || (bgp_flag_check (bgp, BGP_FLAG_MED_CONFED)
428 && confed_as_route)
429 || aspath_cmp_left (new->attr->aspath, exist->attr->aspath)
430 || aspath_cmp_left_confed (new->attr->aspath, exist->attr->aspath)
431 || internal_as_route)
432 {
433 new_med = bgp_med_value (new->attr, bgp);
434 exist_med = bgp_med_value (exist->attr, bgp);
435
436 if (new_med < exist_med)
437 return 1;
438 if (new_med > exist_med)
439 return 0;
440 }
441
442 /* 7. Peer type check. */
443 if (peer_sort (new->peer) == BGP_PEER_EBGP
444 && peer_sort (exist->peer) == BGP_PEER_IBGP)
445 return 1;
446 if (peer_sort (new->peer) == BGP_PEER_EBGP
447 && peer_sort (exist->peer) == BGP_PEER_CONFED)
448 return 1;
449 if (peer_sort (new->peer) == BGP_PEER_IBGP
450 && peer_sort (exist->peer) == BGP_PEER_EBGP)
451 return 0;
452 if (peer_sort (new->peer) == BGP_PEER_CONFED
453 && peer_sort (exist->peer) == BGP_PEER_EBGP)
454 return 0;
455
456 /* 8. IGP metric check. */
fb982c25
PJ
457 if (new->extra || exist->extra)
458 {
459 uint32_t newm = (new->extra ? new->extra->igpmetric : 0);
460 uint32_t existm = (exist->extra ? exist->extra->igpmetric : 0);
461
462 if (newm < existm)
463 return 1;
464 if (newm > existm)
465 return 0;
466 }
718e3744 467
468 /* 9. Maximum path check. */
469
470 /* 10. If both paths are external, prefer the path that was received
471 first (the oldest one). This step minimizes route-flap, since a
472 newer path won't displace an older one, even if it was the
473 preferred route based on the additional decision criteria below. */
474 if (! bgp_flag_check (bgp, BGP_FLAG_COMPARE_ROUTER_ID)
475 && peer_sort (new->peer) == BGP_PEER_EBGP
476 && peer_sort (exist->peer) == BGP_PEER_EBGP)
477 {
478 if (CHECK_FLAG (new->flags, BGP_INFO_SELECTED))
479 return 1;
480 if (CHECK_FLAG (exist->flags, BGP_INFO_SELECTED))
481 return 0;
482 }
483
484 /* 11. Rourter-ID comparision. */
485 if (new->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_ORIGINATOR_ID))
fb982c25 486 new_id.s_addr = new->attr->extra->originator_id.s_addr;
718e3744 487 else
488 new_id.s_addr = new->peer->remote_id.s_addr;
489 if (exist->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_ORIGINATOR_ID))
fb982c25 490 exist_id.s_addr = exist->attr->extra->originator_id.s_addr;
718e3744 491 else
492 exist_id.s_addr = exist->peer->remote_id.s_addr;
493
494 if (ntohl (new_id.s_addr) < ntohl (exist_id.s_addr))
495 return 1;
496 if (ntohl (new_id.s_addr) > ntohl (exist_id.s_addr))
497 return 0;
498
499 /* 12. Cluster length comparision. */
500 if (new->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_CLUSTER_LIST))
fb982c25 501 new_cluster = new->attr->extra->cluster->length;
718e3744 502 else
503 new_cluster = 0;
504 if (exist->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_CLUSTER_LIST))
fb982c25 505 exist_cluster = exist->attr->extra->cluster->length;
718e3744 506 else
507 exist_cluster = 0;
508
509 if (new_cluster < exist_cluster)
510 return 1;
511 if (new_cluster > exist_cluster)
512 return 0;
513
514 /* 13. Neighbor address comparision. */
515 ret = sockunion_cmp (new->peer->su_remote, exist->peer->su_remote);
516
517 if (ret == 1)
518 return 0;
519 if (ret == -1)
520 return 1;
521
522 return 1;
523}
524
94f2b392 525static enum filter_type
718e3744 526bgp_input_filter (struct peer *peer, struct prefix *p, struct attr *attr,
527 afi_t afi, safi_t safi)
528{
529 struct bgp_filter *filter;
530
531 filter = &peer->filter[afi][safi];
532
650f76c2
PJ
533#define FILTER_EXIST_WARN(F,f,filter) \
534 if (BGP_DEBUG (update, UPDATE_IN) \
535 && !(F ## _IN (filter))) \
536 plog_warn (peer->log, "%s: Could not find configured input %s-list %s!", \
537 peer->host, #f, F ## _IN_NAME(filter));
538
539 if (DISTRIBUTE_IN_NAME (filter)) {
540 FILTER_EXIST_WARN(DISTRIBUTE, distribute, filter);
541
718e3744 542 if (access_list_apply (DISTRIBUTE_IN (filter), p) == FILTER_DENY)
543 return FILTER_DENY;
650f76c2 544 }
718e3744 545
650f76c2
PJ
546 if (PREFIX_LIST_IN_NAME (filter)) {
547 FILTER_EXIST_WARN(PREFIX_LIST, prefix, filter);
548
718e3744 549 if (prefix_list_apply (PREFIX_LIST_IN (filter), p) == PREFIX_DENY)
550 return FILTER_DENY;
650f76c2 551 }
718e3744 552
650f76c2
PJ
553 if (FILTER_LIST_IN_NAME (filter)) {
554 FILTER_EXIST_WARN(FILTER_LIST, as, filter);
555
718e3744 556 if (as_list_apply (FILTER_LIST_IN (filter), attr->aspath)== AS_FILTER_DENY)
557 return FILTER_DENY;
650f76c2
PJ
558 }
559
718e3744 560 return FILTER_PERMIT;
650f76c2 561#undef FILTER_EXIST_WARN
718e3744 562}
563
94f2b392 564static enum filter_type
718e3744 565bgp_output_filter (struct peer *peer, struct prefix *p, struct attr *attr,
566 afi_t afi, safi_t safi)
567{
568 struct bgp_filter *filter;
569
570 filter = &peer->filter[afi][safi];
571
650f76c2
PJ
572#define FILTER_EXIST_WARN(F,f,filter) \
573 if (BGP_DEBUG (update, UPDATE_OUT) \
574 && !(F ## _OUT (filter))) \
575 plog_warn (peer->log, "%s: Could not find configured output %s-list %s!", \
576 peer->host, #f, F ## _OUT_NAME(filter));
577
578 if (DISTRIBUTE_OUT_NAME (filter)) {
579 FILTER_EXIST_WARN(DISTRIBUTE, distribute, filter);
580
718e3744 581 if (access_list_apply (DISTRIBUTE_OUT (filter), p) == FILTER_DENY)
582 return FILTER_DENY;
650f76c2 583 }
718e3744 584
650f76c2
PJ
585 if (PREFIX_LIST_OUT_NAME (filter)) {
586 FILTER_EXIST_WARN(PREFIX_LIST, prefix, filter);
587
718e3744 588 if (prefix_list_apply (PREFIX_LIST_OUT (filter), p) == PREFIX_DENY)
589 return FILTER_DENY;
650f76c2 590 }
718e3744 591
650f76c2
PJ
592 if (FILTER_LIST_OUT_NAME (filter)) {
593 FILTER_EXIST_WARN(FILTER_LIST, as, filter);
594
718e3744 595 if (as_list_apply (FILTER_LIST_OUT (filter), attr->aspath) == AS_FILTER_DENY)
596 return FILTER_DENY;
650f76c2 597 }
718e3744 598
599 return FILTER_PERMIT;
650f76c2 600#undef FILTER_EXIST_WARN
718e3744 601}
602
603/* If community attribute includes no_export then return 1. */
94f2b392 604static int
718e3744 605bgp_community_filter (struct peer *peer, struct attr *attr)
606{
607 if (attr->community)
608 {
609 /* NO_ADVERTISE check. */
610 if (community_include (attr->community, COMMUNITY_NO_ADVERTISE))
611 return 1;
612
613 /* NO_EXPORT check. */
614 if (peer_sort (peer) == BGP_PEER_EBGP &&
615 community_include (attr->community, COMMUNITY_NO_EXPORT))
616 return 1;
617
618 /* NO_EXPORT_SUBCONFED check. */
619 if (peer_sort (peer) == BGP_PEER_EBGP
620 || peer_sort (peer) == BGP_PEER_CONFED)
621 if (community_include (attr->community, COMMUNITY_NO_EXPORT_SUBCONFED))
622 return 1;
623 }
624 return 0;
625}
626
627/* Route reflection loop check. */
628static int
629bgp_cluster_filter (struct peer *peer, struct attr *attr)
630{
631 struct in_addr cluster_id;
632
fb982c25 633 if (attr->extra && attr->extra->cluster)
718e3744 634 {
635 if (peer->bgp->config & BGP_CONFIG_CLUSTER_ID)
636 cluster_id = peer->bgp->cluster_id;
637 else
638 cluster_id = peer->bgp->router_id;
639
fb982c25 640 if (cluster_loop_check (attr->extra->cluster, cluster_id))
718e3744 641 return 1;
642 }
643 return 0;
644}
645\f
94f2b392 646static int
718e3744 647bgp_input_modifier (struct peer *peer, struct prefix *p, struct attr *attr,
648 afi_t afi, safi_t safi)
649{
650 struct bgp_filter *filter;
651 struct bgp_info info;
652 route_map_result_t ret;
653
654 filter = &peer->filter[afi][safi];
655
656 /* Apply default weight value. */
fb982c25
PJ
657 if (peer->weight)
658 (bgp_attr_extra_get (attr))->weight = peer->weight;
718e3744 659
660 /* Route map apply. */
661 if (ROUTE_MAP_IN_NAME (filter))
662 {
663 /* Duplicate current value to new strucutre for modification. */
664 info.peer = peer;
665 info.attr = attr;
666
ac41b2a2 667 SET_FLAG (peer->rmap_type, PEER_RMAP_TYPE_IN);
668
718e3744 669 /* Apply BGP route map to the attribute. */
670 ret = route_map_apply (ROUTE_MAP_IN (filter), p, RMAP_BGP, &info);
ac41b2a2 671
672 peer->rmap_type = 0;
673
718e3744 674 if (ret == RMAP_DENYMATCH)
675 {
676 /* Free newly generated AS path and community by route-map. */
677 bgp_attr_flush (attr);
678 return RMAP_DENY;
679 }
680 }
681 return RMAP_PERMIT;
682}
683\f
94f2b392 684static int
fee0f4c6 685bgp_export_modifier (struct peer *rsclient, struct peer *peer,
686 struct prefix *p, struct attr *attr, afi_t afi, safi_t safi)
687{
688 struct bgp_filter *filter;
689 struct bgp_info info;
690 route_map_result_t ret;
691
692 filter = &peer->filter[afi][safi];
693
694 /* Route map apply. */
695 if (ROUTE_MAP_EXPORT_NAME (filter))
696 {
697 /* Duplicate current value to new strucutre for modification. */
698 info.peer = rsclient;
699 info.attr = attr;
700
701 SET_FLAG (rsclient->rmap_type, PEER_RMAP_TYPE_EXPORT);
702
703 /* Apply BGP route map to the attribute. */
704 ret = route_map_apply (ROUTE_MAP_EXPORT (filter), p, RMAP_BGP, &info);
705
706 rsclient->rmap_type = 0;
707
708 if (ret == RMAP_DENYMATCH)
709 {
710 /* Free newly generated AS path and community by route-map. */
711 bgp_attr_flush (attr);
712 return RMAP_DENY;
713 }
714 }
715 return RMAP_PERMIT;
716}
717
94f2b392 718static int
fee0f4c6 719bgp_import_modifier (struct peer *rsclient, struct peer *peer,
720 struct prefix *p, struct attr *attr, afi_t afi, safi_t safi)
721{
722 struct bgp_filter *filter;
723 struct bgp_info info;
724 route_map_result_t ret;
725
726 filter = &rsclient->filter[afi][safi];
727
728 /* Apply default weight value. */
fb982c25
PJ
729 if (peer->weight)
730 (bgp_attr_extra_get (attr))->weight = peer->weight;
fee0f4c6 731
732 /* Route map apply. */
733 if (ROUTE_MAP_IMPORT_NAME (filter))
734 {
735 /* Duplicate current value to new strucutre for modification. */
736 info.peer = peer;
737 info.attr = attr;
738
739 SET_FLAG (peer->rmap_type, PEER_RMAP_TYPE_IMPORT);
740
741 /* Apply BGP route map to the attribute. */
742 ret = route_map_apply (ROUTE_MAP_IMPORT (filter), p, RMAP_BGP, &info);
743
744 peer->rmap_type = 0;
745
746 if (ret == RMAP_DENYMATCH)
747 {
748 /* Free newly generated AS path and community by route-map. */
749 bgp_attr_flush (attr);
750 return RMAP_DENY;
751 }
752 }
753 return RMAP_PERMIT;
754}
755\f
94f2b392 756static int
718e3744 757bgp_announce_check (struct bgp_info *ri, struct peer *peer, struct prefix *p,
758 struct attr *attr, afi_t afi, safi_t safi)
759{
760 int ret;
761 char buf[SU_ADDRSTRLEN];
762 struct bgp_filter *filter;
718e3744 763 struct peer *from;
764 struct bgp *bgp;
718e3744 765 int transparent;
766 int reflect;
767
768 from = ri->peer;
769 filter = &peer->filter[afi][safi];
770 bgp = peer->bgp;
771
750e8146
PJ
772 if (DISABLE_BGP_ANNOUNCE)
773 return 0;
718e3744 774
fee0f4c6 775 /* Do not send announces to RS-clients from the 'normal' bgp_table. */
776 if (CHECK_FLAG(peer->af_flags[afi][safi], PEER_FLAG_RSERVER_CLIENT))
777 return 0;
778
718e3744 779 /* Do not send back route to sender. */
780 if (from == peer)
781 return 0;
782
35be31b6 783 /* If peer's id and route's nexthop are same. draft-ietf-idr-bgp4-23 5.1.3 */
784 if (p->family == AF_INET
785 && IPV4_ADDR_SAME(&peer->remote_id, &ri->attr->nexthop))
786 return 0;
787#ifdef HAVE_IPV6
788 if (p->family == AF_INET6
789 && IPV6_ADDR_SAME(&peer->remote_id, &ri->attr->nexthop))
790 return 0;
791#endif
792
718e3744 793 /* Aggregate-address suppress check. */
fb982c25 794 if (ri->extra && ri->extra->suppress)
718e3744 795 if (! UNSUPPRESS_MAP_NAME (filter))
796 return 0;
797
798 /* Default route check. */
799 if (CHECK_FLAG (peer->af_sflags[afi][safi], PEER_STATUS_DEFAULT_ORIGINATE))
800 {
801 if (p->family == AF_INET && p->u.prefix4.s_addr == INADDR_ANY)
802 return 0;
803#ifdef HAVE_IPV6
804 else if (p->family == AF_INET6 && p->prefixlen == 0)
805 return 0;
806#endif /* HAVE_IPV6 */
807 }
808
286e1e71 809 /* Transparency check. */
810 if (CHECK_FLAG (peer->af_flags[afi][safi], PEER_FLAG_RSERVER_CLIENT)
811 && CHECK_FLAG (from->af_flags[afi][safi], PEER_FLAG_RSERVER_CLIENT))
812 transparent = 1;
813 else
814 transparent = 0;
815
718e3744 816 /* If community is not disabled check the no-export and local. */
286e1e71 817 if (! transparent && bgp_community_filter (peer, ri->attr))
718e3744 818 return 0;
819
820 /* If the attribute has originator-id and it is same as remote
821 peer's id. */
822 if (ri->attr->flag & ATTR_FLAG_BIT (BGP_ATTR_ORIGINATOR_ID))
823 {
fb982c25 824 if (IPV4_ADDR_SAME (&peer->remote_id, &ri->attr->extra->originator_id))
718e3744 825 {
826 if (BGP_DEBUG (filter, FILTER))
d2c1f16b 827 zlog (peer->log, LOG_DEBUG,
718e3744 828 "%s [Update:SEND] %s/%d originator-id is same as remote router-id",
829 peer->host,
830 inet_ntop(p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
831 p->prefixlen);
832 return 0;
833 }
834 }
835
836 /* ORF prefix-list filter check */
837 if (CHECK_FLAG (peer->af_cap[afi][safi], PEER_CAP_ORF_PREFIX_RM_ADV)
838 && (CHECK_FLAG (peer->af_cap[afi][safi], PEER_CAP_ORF_PREFIX_SM_RCV)
839 || CHECK_FLAG (peer->af_cap[afi][safi], PEER_CAP_ORF_PREFIX_SM_OLD_RCV)))
840 if (peer->orf_plist[afi][safi])
841 {
842 if (prefix_list_apply (peer->orf_plist[afi][safi], p) == PREFIX_DENY)
843 return 0;
844 }
845
846 /* Output filter check. */
847 if (bgp_output_filter (peer, p, ri->attr, afi, safi) == FILTER_DENY)
848 {
849 if (BGP_DEBUG (filter, FILTER))
d2c1f16b 850 zlog (peer->log, LOG_DEBUG,
718e3744 851 "%s [Update:SEND] %s/%d is filtered",
852 peer->host,
853 inet_ntop(p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
854 p->prefixlen);
855 return 0;
856 }
857
858#ifdef BGP_SEND_ASPATH_CHECK
859 /* AS path loop check. */
860 if (aspath_loop_check (ri->attr->aspath, peer->as))
861 {
862 if (BGP_DEBUG (filter, FILTER))
d2c1f16b 863 zlog (peer->log, LOG_DEBUG,
aea339f7 864 "%s [Update:SEND] suppress announcement to peer AS %u is AS path.",
718e3744 865 peer->host, peer->as);
866 return 0;
867 }
868#endif /* BGP_SEND_ASPATH_CHECK */
869
870 /* If we're a CONFED we need to loop check the CONFED ID too */
871 if (CHECK_FLAG(bgp->config, BGP_CONFIG_CONFEDERATION))
872 {
873 if (aspath_loop_check(ri->attr->aspath, bgp->confed_id))
874 {
875 if (BGP_DEBUG (filter, FILTER))
d2c1f16b 876 zlog (peer->log, LOG_DEBUG,
aea339f7 877 "%s [Update:SEND] suppress announcement to peer AS %u is AS path.",
718e3744 878 peer->host,
879 bgp->confed_id);
880 return 0;
881 }
882 }
883
884 /* Route-Reflect check. */
885 if (peer_sort (from) == BGP_PEER_IBGP && peer_sort (peer) == BGP_PEER_IBGP)
886 reflect = 1;
887 else
888 reflect = 0;
889
890 /* IBGP reflection check. */
891 if (reflect)
892 {
893 /* A route from a Client peer. */
894 if (CHECK_FLAG (from->af_flags[afi][safi], PEER_FLAG_REFLECTOR_CLIENT))
895 {
896 /* Reflect to all the Non-Client peers and also to the
897 Client peers other than the originator. Originator check
898 is already done. So there is noting to do. */
899 /* no bgp client-to-client reflection check. */
900 if (bgp_flag_check (bgp, BGP_FLAG_NO_CLIENT_TO_CLIENT))
901 if (CHECK_FLAG (peer->af_flags[afi][safi], PEER_FLAG_REFLECTOR_CLIENT))
902 return 0;
903 }
904 else
905 {
906 /* A route from a Non-client peer. Reflect to all other
907 clients. */
908 if (! CHECK_FLAG (peer->af_flags[afi][safi], PEER_FLAG_REFLECTOR_CLIENT))
909 return 0;
910 }
911 }
41367172
PJ
912
913 /* AS-Pathlimit check */
914 if (ri->attr->pathlimit.ttl && peer_sort (peer) == BGP_PEER_EBGP)
915 /* Our ASN has not yet been pre-pended, that's done in packet_attribute
916 * on output. Hence the test here is for >=.
917 */
918 if (aspath_count_hops (ri->attr->aspath) >= ri->attr->pathlimit.ttl)
919 {
920 if (BGP_DEBUG (filter, FILTER))
921 zlog_info ("%s [Update:SEND] suppressed, AS-Pathlimit TTL %u exceeded",
922 peer->host, ri->attr->pathlimit.ttl);
923 return 0;
924 }
925
718e3744 926 /* For modify attribute, copy it to temporary structure. */
fb982c25
PJ
927 bgp_attr_dup (attr, ri->attr);
928
718e3744 929 /* If local-preference is not set. */
930 if ((peer_sort (peer) == BGP_PEER_IBGP
931 || peer_sort (peer) == BGP_PEER_CONFED)
932 && (! (attr->flag & ATTR_FLAG_BIT (BGP_ATTR_LOCAL_PREF))))
933 {
934 attr->flag |= ATTR_FLAG_BIT (BGP_ATTR_LOCAL_PREF);
935 attr->local_pref = bgp->default_local_pref;
936 }
937
718e3744 938 /* Remove MED if its an EBGP peer - will get overwritten by route-maps */
939 if (peer_sort (peer) == BGP_PEER_EBGP
940 && attr->flag & ATTR_FLAG_BIT (BGP_ATTR_MULTI_EXIT_DISC))
941 {
942 if (ri->peer != bgp->peer_self && ! transparent
943 && ! CHECK_FLAG (peer->af_flags[afi][safi], PEER_FLAG_MED_UNCHANGED))
944 attr->flag &= ~(ATTR_FLAG_BIT (BGP_ATTR_MULTI_EXIT_DISC));
945 }
946
947 /* next-hop-set */
948 if (transparent || reflect
949 || (CHECK_FLAG (peer->af_flags[afi][safi], PEER_FLAG_NEXTHOP_UNCHANGED)
950 && ((p->family == AF_INET && attr->nexthop.s_addr)
286e1e71 951#ifdef HAVE_IPV6
fee0f4c6 952 || (p->family == AF_INET6 &&
fb982c25 953 ! IN6_IS_ADDR_UNSPECIFIED(&attr->extra->mp_nexthop_global))
286e1e71 954#endif /* HAVE_IPV6 */
955 )))
718e3744 956 {
957 /* NEXT-HOP Unchanged. */
958 }
959 else if (CHECK_FLAG (peer->af_flags[afi][safi], PEER_FLAG_NEXTHOP_SELF)
960 || (p->family == AF_INET && attr->nexthop.s_addr == 0)
961#ifdef HAVE_IPV6
fee0f4c6 962 || (p->family == AF_INET6 &&
fb982c25 963 IN6_IS_ADDR_UNSPECIFIED(&attr->extra->mp_nexthop_global))
718e3744 964#endif /* HAVE_IPV6 */
965 || (peer_sort (peer) == BGP_PEER_EBGP
966 && bgp_multiaccess_check_v4 (attr->nexthop, peer->host) == 0))
967 {
968 /* Set IPv4 nexthop. */
969 if (p->family == AF_INET)
970 {
971 if (safi == SAFI_MPLS_VPN)
fb982c25
PJ
972 memcpy (&attr->extra->mp_nexthop_global_in, &peer->nexthop.v4,
973 IPV4_MAX_BYTELEN);
718e3744 974 else
975 memcpy (&attr->nexthop, &peer->nexthop.v4, IPV4_MAX_BYTELEN);
976 }
977#ifdef HAVE_IPV6
978 /* Set IPv6 nexthop. */
979 if (p->family == AF_INET6)
980 {
981 /* IPv6 global nexthop must be included. */
fb982c25 982 memcpy (&attr->extra->mp_nexthop_global, &peer->nexthop.v6_global,
718e3744 983 IPV6_MAX_BYTELEN);
fb982c25 984 attr->extra->mp_nexthop_len = 16;
718e3744 985 }
986#endif /* HAVE_IPV6 */
987 }
988
989#ifdef HAVE_IPV6
990 if (p->family == AF_INET6)
991 {
fee0f4c6 992 /* Left nexthop_local unchanged if so configured. */
993 if ( CHECK_FLAG (peer->af_flags[afi][safi],
994 PEER_FLAG_NEXTHOP_LOCAL_UNCHANGED) )
995 {
fb982c25
PJ
996 if ( IN6_IS_ADDR_LINKLOCAL (&attr->extra->mp_nexthop_local) )
997 attr->extra->mp_nexthop_len=32;
fee0f4c6 998 else
fb982c25 999 attr->extra->mp_nexthop_len=16;
fee0f4c6 1000 }
1001
1002 /* Default nexthop_local treatment for non-RS-Clients */
1003 else
1004 {
718e3744 1005 /* Link-local address should not be transit to different peer. */
fb982c25 1006 attr->extra->mp_nexthop_len = 16;
718e3744 1007
1008 /* Set link-local address for shared network peer. */
1009 if (peer->shared_network
1010 && ! IN6_IS_ADDR_UNSPECIFIED (&peer->nexthop.v6_local))
1011 {
fb982c25 1012 memcpy (&attr->extra->mp_nexthop_local, &peer->nexthop.v6_local,
718e3744 1013 IPV6_MAX_BYTELEN);
fb982c25 1014 attr->extra->mp_nexthop_len = 32;
718e3744 1015 }
1016
1017 /* If bgpd act as BGP-4+ route-reflector, do not send link-local
1018 address.*/
1019 if (reflect)
fb982c25 1020 attr->extra->mp_nexthop_len = 16;
718e3744 1021
1022 /* If BGP-4+ link-local nexthop is not link-local nexthop. */
1023 if (! IN6_IS_ADDR_LINKLOCAL (&peer->nexthop.v6_local))
fb982c25 1024 attr->extra->mp_nexthop_len = 16;
718e3744 1025 }
fee0f4c6 1026
1027 }
718e3744 1028#endif /* HAVE_IPV6 */
1029
41367172
PJ
1030 /* AS-Pathlimit: Check ASN for private/confed */
1031 if (attr->pathlimit.ttl)
1032 {
1033 /* locally originated update */
1034 if (!attr->pathlimit.as)
1035 attr->pathlimit.as = peer->local_as;
1036
1037 /* if the AS_PATHLIMIT attribute is attached to a prefix by a
1038 member of a confederation, then when the prefix is advertised outside
1039 of the confederation boundary, then the AS number of the
1040 confederation member inside of the AS_PATHLIMIT attribute should be
1041 replaced by the confederation's AS number. */
1042 if (peer_sort (from) == BGP_PEER_CONFED
1043 && peer_sort (peer) != BGP_PEER_CONFED)
1044 attr->pathlimit.as = peer->local_as;
1045
1046 /* Private ASN should be updated whenever announcement leaves
1047 * private space. This is deliberately done after simple confed
1048 * based update..
1049 */
1050 if (attr->pathlimit.as >= BGP_PRIVATE_AS_MIN
1051 && attr->pathlimit.as <= BGP_PRIVATE_AS_MAX)
1052 {
1053 if (peer->local_as < BGP_PRIVATE_AS_MIN
1054 || peer->local_as > BGP_PRIVATE_AS_MAX)
1055 attr->pathlimit.as = peer->local_as;
1056 /* Ours is private, try using theirs.. */
1057 else if (peer->as < BGP_PRIVATE_AS_MIN
1058 || peer->local_as > BGP_PRIVATE_AS_MAX)
1059 attr->pathlimit.as = peer->as;
1060 }
1061 }
1062
718e3744 1063 /* If this is EBGP peer and remove-private-AS is set. */
1064 if (peer_sort (peer) == BGP_PEER_EBGP
1065 && peer_af_flag_check (peer, afi, safi, PEER_FLAG_REMOVE_PRIVATE_AS)
1066 && aspath_private_as_check (attr->aspath))
1067 attr->aspath = aspath_empty_get ();
1068
1069 /* Route map & unsuppress-map apply. */
1070 if (ROUTE_MAP_OUT_NAME (filter)
fb982c25 1071 || (ri->extra && ri->extra->suppress) )
718e3744 1072 {
7c7fa1b4 1073 struct bgp_info info;
9eda90ce 1074 struct attr dummy_attr = { 0 };
7c7fa1b4 1075
718e3744 1076 info.peer = peer;
1077 info.attr = attr;
1078
1079 /* The route reflector is not allowed to modify the attributes
1080 of the reflected IBGP routes. */
1081 if (peer_sort (from) == BGP_PEER_IBGP
1082 && peer_sort (peer) == BGP_PEER_IBGP)
1083 {
fb982c25 1084 bgp_attr_dup (&dummy_attr, attr);
9eda90ce 1085 info.attr = &dummy_attr;
718e3744 1086 }
ac41b2a2 1087
1088 SET_FLAG (peer->rmap_type, PEER_RMAP_TYPE_OUT);
1089
fb982c25 1090 if (ri->extra && ri->extra->suppress)
718e3744 1091 ret = route_map_apply (UNSUPPRESS_MAP (filter), p, RMAP_BGP, &info);
1092 else
1093 ret = route_map_apply (ROUTE_MAP_OUT (filter), p, RMAP_BGP, &info);
1094
ac41b2a2 1095 peer->rmap_type = 0;
fb982c25 1096
9eda90ce
PJ
1097 if (dummy_attr.extra)
1098 bgp_attr_extra_free (&dummy_attr);
fb982c25 1099
718e3744 1100 if (ret == RMAP_DENYMATCH)
1101 {
1102 bgp_attr_flush (attr);
1103 return 0;
1104 }
1105 }
1106 return 1;
1107}
1108
94f2b392 1109static int
fee0f4c6 1110bgp_announce_check_rsclient (struct bgp_info *ri, struct peer *rsclient,
1111 struct prefix *p, struct attr *attr, afi_t afi, safi_t safi)
1112{
1113 int ret;
1114 char buf[SU_ADDRSTRLEN];
1115 struct bgp_filter *filter;
1116 struct bgp_info info;
1117 struct peer *from;
1118 struct bgp *bgp;
1119
1120 from = ri->peer;
1121 filter = &rsclient->filter[afi][safi];
1122 bgp = rsclient->bgp;
1123
750e8146
PJ
1124 if (DISABLE_BGP_ANNOUNCE)
1125 return 0;
fee0f4c6 1126
1127 /* Do not send back route to sender. */
1128 if (from == rsclient)
1129 return 0;
1130
1131 /* Aggregate-address suppress check. */
fb982c25 1132 if (ri->extra && ri->extra->suppress)
fee0f4c6 1133 if (! UNSUPPRESS_MAP_NAME (filter))
1134 return 0;
1135
1136 /* Default route check. */
1137 if (CHECK_FLAG (rsclient->af_sflags[afi][safi],
1138 PEER_STATUS_DEFAULT_ORIGINATE))
1139 {
1140 if (p->family == AF_INET && p->u.prefix4.s_addr == INADDR_ANY)
1141 return 0;
1142#ifdef HAVE_IPV6
1143 else if (p->family == AF_INET6 && p->prefixlen == 0)
1144 return 0;
1145#endif /* HAVE_IPV6 */
1146 }
1147
1148 /* If the attribute has originator-id and it is same as remote
1149 peer's id. */
1150 if (ri->attr->flag & ATTR_FLAG_BIT (BGP_ATTR_ORIGINATOR_ID))
1151 {
fb982c25
PJ
1152 if (IPV4_ADDR_SAME (&rsclient->remote_id,
1153 &ri->attr->extra->originator_id))
fee0f4c6 1154 {
1155 if (BGP_DEBUG (filter, FILTER))
d2c1f16b 1156 zlog (rsclient->log, LOG_DEBUG,
fee0f4c6 1157 "%s [Update:SEND] %s/%d originator-id is same as remote router-id",
1158 rsclient->host,
1159 inet_ntop(p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
1160 p->prefixlen);
1161 return 0;
1162 }
1163 }
1164
1165 /* ORF prefix-list filter check */
1166 if (CHECK_FLAG (rsclient->af_cap[afi][safi], PEER_CAP_ORF_PREFIX_RM_ADV)
1167 && (CHECK_FLAG (rsclient->af_cap[afi][safi], PEER_CAP_ORF_PREFIX_SM_RCV)
1168 || CHECK_FLAG (rsclient->af_cap[afi][safi], PEER_CAP_ORF_PREFIX_SM_OLD_RCV)))
1169 if (rsclient->orf_plist[afi][safi])
1170 {
1171 if (prefix_list_apply (rsclient->orf_plist[afi][safi], p) == PREFIX_DENY)
1172 return 0;
1173 }
1174
1175 /* Output filter check. */
1176 if (bgp_output_filter (rsclient, p, ri->attr, afi, safi) == FILTER_DENY)
1177 {
1178 if (BGP_DEBUG (filter, FILTER))
d2c1f16b 1179 zlog (rsclient->log, LOG_DEBUG,
fee0f4c6 1180 "%s [Update:SEND] %s/%d is filtered",
1181 rsclient->host,
1182 inet_ntop(p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
1183 p->prefixlen);
1184 return 0;
1185 }
1186
1187#ifdef BGP_SEND_ASPATH_CHECK
1188 /* AS path loop check. */
1189 if (aspath_loop_check (ri->attr->aspath, rsclient->as))
1190 {
1191 if (BGP_DEBUG (filter, FILTER))
d2c1f16b 1192 zlog (rsclient->log, LOG_DEBUG,
aea339f7 1193 "%s [Update:SEND] suppress announcement to peer AS %u is AS path.",
fee0f4c6 1194 rsclient->host, rsclient->as);
1195 return 0;
1196 }
1197#endif /* BGP_SEND_ASPATH_CHECK */
1198
1199 /* For modify attribute, copy it to temporary structure. */
9eda90ce 1200 bgp_attr_dup (attr, ri->attr);
fee0f4c6 1201
1202 /* next-hop-set */
1203 if ((p->family == AF_INET && attr->nexthop.s_addr == 0)
1204#ifdef HAVE_IPV6
1205 || (p->family == AF_INET6 &&
fb982c25 1206 IN6_IS_ADDR_UNSPECIFIED(&attr->extra->mp_nexthop_global))
fee0f4c6 1207#endif /* HAVE_IPV6 */
1208 )
1209 {
1210 /* Set IPv4 nexthop. */
1211 if (p->family == AF_INET)
1212 {
1213 if (safi == SAFI_MPLS_VPN)
fb982c25 1214 memcpy (&attr->extra->mp_nexthop_global_in, &rsclient->nexthop.v4,
fee0f4c6 1215 IPV4_MAX_BYTELEN);
1216 else
1217 memcpy (&attr->nexthop, &rsclient->nexthop.v4, IPV4_MAX_BYTELEN);
1218 }
1219#ifdef HAVE_IPV6
1220 /* Set IPv6 nexthop. */
1221 if (p->family == AF_INET6)
1222 {
1223 /* IPv6 global nexthop must be included. */
fb982c25 1224 memcpy (&attr->extra->mp_nexthop_global, &rsclient->nexthop.v6_global,
fee0f4c6 1225 IPV6_MAX_BYTELEN);
fb982c25 1226 attr->extra->mp_nexthop_len = 16;
fee0f4c6 1227 }
1228#endif /* HAVE_IPV6 */
1229 }
1230
1231#ifdef HAVE_IPV6
1232 if (p->family == AF_INET6)
1233 {
fb982c25
PJ
1234 struct attr_extra *attre = attr->extra;
1235
1236 assert (attr->extra);
1237
fee0f4c6 1238 /* Left nexthop_local unchanged if so configured. */
1239 if ( CHECK_FLAG (rsclient->af_flags[afi][safi],
1240 PEER_FLAG_NEXTHOP_LOCAL_UNCHANGED) )
1241 {
fb982c25
PJ
1242 if ( IN6_IS_ADDR_LINKLOCAL (&attre->mp_nexthop_local) )
1243 attre->mp_nexthop_len=32;
fee0f4c6 1244 else
fb982c25 1245 attre->mp_nexthop_len=16;
fee0f4c6 1246 }
1247
1248 /* Default nexthop_local treatment for RS-Clients */
1249 else
1250 {
1251 /* Announcer and RS-Client are both in the same network */
1252 if (rsclient->shared_network && from->shared_network &&
1253 (rsclient->ifindex == from->ifindex))
1254 {
fb982c25
PJ
1255 if ( IN6_IS_ADDR_LINKLOCAL (&attre->mp_nexthop_local) )
1256 attre->mp_nexthop_len=32;
fee0f4c6 1257 else
fb982c25 1258 attre->mp_nexthop_len=16;
fee0f4c6 1259 }
1260
1261 /* Set link-local address for shared network peer. */
1262 else if (rsclient->shared_network
1263 && IN6_IS_ADDR_LINKLOCAL (&rsclient->nexthop.v6_local))
1264 {
fb982c25 1265 memcpy (&attre->mp_nexthop_local, &rsclient->nexthop.v6_local,
fee0f4c6 1266 IPV6_MAX_BYTELEN);
fb982c25 1267 attre->mp_nexthop_len = 32;
fee0f4c6 1268 }
1269
1270 else
fb982c25 1271 attre->mp_nexthop_len = 16;
fee0f4c6 1272 }
1273
1274 }
1275#endif /* HAVE_IPV6 */
1276
1277
1278 /* If this is EBGP peer and remove-private-AS is set. */
1279 if (peer_sort (rsclient) == BGP_PEER_EBGP
1280 && peer_af_flag_check (rsclient, afi, safi, PEER_FLAG_REMOVE_PRIVATE_AS)
1281 && aspath_private_as_check (attr->aspath))
1282 attr->aspath = aspath_empty_get ();
1283
1284 /* Route map & unsuppress-map apply. */
fb982c25 1285 if (ROUTE_MAP_OUT_NAME (filter) || (ri->extra && ri->extra->suppress) )
fee0f4c6 1286 {
1287 info.peer = rsclient;
1288 info.attr = attr;
1289
1290 SET_FLAG (rsclient->rmap_type, PEER_RMAP_TYPE_OUT);
1291
fb982c25 1292 if (ri->extra && ri->extra->suppress)
fee0f4c6 1293 ret = route_map_apply (UNSUPPRESS_MAP (filter), p, RMAP_BGP, &info);
1294 else
1295 ret = route_map_apply (ROUTE_MAP_OUT (filter), p, RMAP_BGP, &info);
1296
1297 rsclient->rmap_type = 0;
1298
1299 if (ret == RMAP_DENYMATCH)
1300 {
1301 bgp_attr_flush (attr);
1302 return 0;
1303 }
1304 }
1305
1306 return 1;
1307}
1308
1309struct bgp_info_pair
1310{
1311 struct bgp_info *old;
1312 struct bgp_info *new;
1313};
1314
94f2b392 1315static void
fee0f4c6 1316bgp_best_selection (struct bgp *bgp, struct bgp_node *rn, struct bgp_info_pair *result)
718e3744 1317{
718e3744 1318 struct bgp_info *new_select;
1319 struct bgp_info *old_select;
fee0f4c6 1320 struct bgp_info *ri;
718e3744 1321 struct bgp_info *ri1;
1322 struct bgp_info *ri2;
b40d939b 1323 struct bgp_info *nextri = NULL;
1324
718e3744 1325 /* bgp deterministic-med */
1326 new_select = NULL;
1327 if (bgp_flag_check (bgp, BGP_FLAG_DETERMINISTIC_MED))
1328 for (ri1 = rn->info; ri1; ri1 = ri1->next)
1329 {
1330 if (CHECK_FLAG (ri1->flags, BGP_INFO_DMED_CHECK))
1331 continue;
1332 if (BGP_INFO_HOLDDOWN (ri1))
1333 continue;
1334
1335 new_select = ri1;
1336 if (ri1->next)
1337 for (ri2 = ri1->next; ri2; ri2 = ri2->next)
1338 {
1339 if (CHECK_FLAG (ri2->flags, BGP_INFO_DMED_CHECK))
1340 continue;
1341 if (BGP_INFO_HOLDDOWN (ri2))
1342 continue;
1343
1344 if (aspath_cmp_left (ri1->attr->aspath, ri2->attr->aspath)
1345 || aspath_cmp_left_confed (ri1->attr->aspath,
1346 ri2->attr->aspath))
1347 {
1348 if (bgp_info_cmp (bgp, ri2, new_select))
1349 {
1a392d46 1350 bgp_info_unset_flag (rn, new_select, BGP_INFO_DMED_SELECTED);
718e3744 1351 new_select = ri2;
1352 }
1353
1a392d46 1354 bgp_info_set_flag (rn, ri2, BGP_INFO_DMED_CHECK);
718e3744 1355 }
1356 }
1a392d46
PJ
1357 bgp_info_set_flag (rn, new_select, BGP_INFO_DMED_CHECK);
1358 bgp_info_set_flag (rn, new_select, BGP_INFO_DMED_SELECTED);
718e3744 1359 }
1360
1361 /* Check old selected route and new selected route. */
1362 old_select = NULL;
1363 new_select = NULL;
b40d939b 1364 for (ri = rn->info; (ri != NULL) && (nextri = ri->next, 1); ri = nextri)
718e3744 1365 {
1366 if (CHECK_FLAG (ri->flags, BGP_INFO_SELECTED))
1367 old_select = ri;
1368
1369 if (BGP_INFO_HOLDDOWN (ri))
b40d939b 1370 {
1371 /* reap REMOVED routes, if needs be
1372 * selected route must stay for a while longer though
1373 */
1374 if (CHECK_FLAG (ri->flags, BGP_INFO_REMOVED)
1375 && (ri != old_select))
1376 bgp_info_reap (rn, ri);
1377
1378 continue;
1379 }
718e3744 1380
1381 if (bgp_flag_check (bgp, BGP_FLAG_DETERMINISTIC_MED)
1382 && (! CHECK_FLAG (ri->flags, BGP_INFO_DMED_SELECTED)))
1383 {
1a392d46 1384 bgp_info_unset_flag (rn, ri, BGP_INFO_DMED_CHECK);
718e3744 1385 continue;
1386 }
1a392d46
PJ
1387 bgp_info_unset_flag (rn, ri, BGP_INFO_DMED_CHECK);
1388 bgp_info_unset_flag (rn, ri, BGP_INFO_DMED_SELECTED);
718e3744 1389
1390 if (bgp_info_cmp (bgp, ri, new_select))
1391 new_select = ri;
1392 }
b40d939b 1393
fee0f4c6 1394 result->old = old_select;
1395 result->new = new_select;
1396
1397 return;
1398}
1399
94f2b392 1400static int
fee0f4c6 1401bgp_process_announce_selected (struct peer *peer, struct bgp_info *selected,
9eda90ce
PJ
1402 struct bgp_node *rn, afi_t afi, safi_t safi)
1403{
fee0f4c6 1404 struct prefix *p;
9eda90ce 1405 struct attr attr = { 0 };
fee0f4c6 1406
1407 p = &rn->p;
1408
9eda90ce
PJ
1409 /* Announce route to Established peer. */
1410 if (peer->status != Established)
fee0f4c6 1411 return 0;
718e3744 1412
9eda90ce
PJ
1413 /* Address family configuration check. */
1414 if (! peer->afc_nego[afi][safi])
fee0f4c6 1415 return 0;
718e3744 1416
9eda90ce 1417 /* First update is deferred until ORF or ROUTE-REFRESH is received */
fee0f4c6 1418 if (CHECK_FLAG (peer->af_sflags[afi][safi],
1419 PEER_STATUS_ORF_WAIT_REFRESH))
1420 return 0;
718e3744 1421
fee0f4c6 1422 switch (rn->table->type)
1423 {
1424 case BGP_TABLE_MAIN:
718e3744 1425 /* Announcement to peer->conf. If the route is filtered,
1426 withdraw it. */
9eda90ce
PJ
1427 if (selected && bgp_announce_check (selected, peer, p, &attr, afi, safi))
1428 bgp_adj_out_set (rn, peer, p, &attr, afi, safi, selected);
fee0f4c6 1429 else
1430 bgp_adj_out_unset (rn, peer, p, afi, safi);
1431 break;
1432 case BGP_TABLE_RSCLIENT:
1433 /* Announcement to peer->conf. If the route is filtered,
1434 withdraw it. */
9eda90ce
PJ
1435 if (selected &&
1436 bgp_announce_check_rsclient (selected, peer, p, &attr, afi, safi))
1437 bgp_adj_out_set (rn, peer, p, &attr, afi, safi, selected);
1438 else
1439 bgp_adj_out_unset (rn, peer, p, afi, safi);
fee0f4c6 1440 break;
1441 }
9eda90ce
PJ
1442
1443 bgp_attr_extra_free (&attr);
1444
fee0f4c6 1445 return 0;
200df115 1446}
fee0f4c6 1447
200df115 1448struct bgp_process_queue
fee0f4c6 1449{
200df115 1450 struct bgp *bgp;
1451 struct bgp_node *rn;
1452 afi_t afi;
1453 safi_t safi;
1454};
1455
1456static wq_item_status
0fb58d5d 1457bgp_process_rsclient (struct work_queue *wq, void *data)
200df115 1458{
0fb58d5d 1459 struct bgp_process_queue *pq = data;
200df115 1460 struct bgp *bgp = pq->bgp;
1461 struct bgp_node *rn = pq->rn;
1462 afi_t afi = pq->afi;
1463 safi_t safi = pq->safi;
fee0f4c6 1464 struct bgp_info *new_select;
1465 struct bgp_info *old_select;
1466 struct bgp_info_pair old_and_new;
1eb8ef25 1467 struct listnode *node, *nnode;
200df115 1468 struct peer *rsclient = rn->table->owner;
1469
fee0f4c6 1470 /* Best path selection. */
1471 bgp_best_selection (bgp, rn, &old_and_new);
1472 new_select = old_and_new.new;
1473 old_select = old_and_new.old;
1474
200df115 1475 if (CHECK_FLAG (rsclient->sflags, PEER_STATUS_GROUP))
1476 {
228da428
CC
1477 if (rsclient->group)
1478 for (ALL_LIST_ELEMENTS (rsclient->group->peer, node, nnode, rsclient))
1479 {
1480 /* Nothing to do. */
1481 if (old_select && old_select == new_select)
1482 if (!CHECK_FLAG (old_select->flags, BGP_INFO_ATTR_CHANGED))
1483 continue;
1484
1485 if (old_select)
1486 bgp_info_unset_flag (rn, old_select, BGP_INFO_SELECTED);
1487 if (new_select)
1488 {
1489 bgp_info_set_flag (rn, new_select, BGP_INFO_SELECTED);
1490 bgp_info_unset_flag (rn, new_select, BGP_INFO_ATTR_CHANGED);
1491 }
1492
1493 bgp_process_announce_selected (rsclient, new_select, rn,
1494 afi, safi);
1495 }
200df115 1496 }
1497 else
1498 {
b7395791 1499 if (old_select)
1a392d46 1500 bgp_info_unset_flag (rn, old_select, BGP_INFO_SELECTED);
b7395791 1501 if (new_select)
1502 {
1a392d46
PJ
1503 bgp_info_set_flag (rn, new_select, BGP_INFO_SELECTED);
1504 bgp_info_unset_flag (rn, new_select, BGP_INFO_ATTR_CHANGED);
b7395791 1505 }
9eda90ce 1506 bgp_process_announce_selected (rsclient, new_select, rn, afi, safi);
200df115 1507 }
1508
b40d939b 1509 if (old_select && CHECK_FLAG (old_select->flags, BGP_INFO_REMOVED))
1510 bgp_info_reap (rn, old_select);
1511
200df115 1512 UNSET_FLAG (rn->flags, BGP_NODE_PROCESS_SCHEDULED);
1513 return WQ_SUCCESS;
fee0f4c6 1514}
1515
200df115 1516static wq_item_status
0fb58d5d 1517bgp_process_main (struct work_queue *wq, void *data)
200df115 1518{
0fb58d5d 1519 struct bgp_process_queue *pq = data;
200df115 1520 struct bgp *bgp = pq->bgp;
1521 struct bgp_node *rn = pq->rn;
1522 afi_t afi = pq->afi;
1523 safi_t safi = pq->safi;
1524 struct prefix *p = &rn->p;
fee0f4c6 1525 struct bgp_info *new_select;
1526 struct bgp_info *old_select;
1527 struct bgp_info_pair old_and_new;
1eb8ef25 1528 struct listnode *node, *nnode;
fee0f4c6 1529 struct peer *peer;
fb982c25 1530
fee0f4c6 1531 /* Best path selection. */
1532 bgp_best_selection (bgp, rn, &old_and_new);
1533 old_select = old_and_new.old;
1534 new_select = old_and_new.new;
1535
1536 /* Nothing to do. */
1537 if (old_select && old_select == new_select)
1538 {
1539 if (! CHECK_FLAG (old_select->flags, BGP_INFO_ATTR_CHANGED))
200df115 1540 {
1541 if (CHECK_FLAG (old_select->flags, BGP_INFO_IGP_CHANGED))
1542 bgp_zebra_announce (p, old_select, bgp);
1543
1544 UNSET_FLAG (rn->flags, BGP_NODE_PROCESS_SCHEDULED);
1545 return WQ_SUCCESS;
1546 }
fee0f4c6 1547 }
1548
338b3424 1549 if (old_select)
1a392d46 1550 bgp_info_unset_flag (rn, old_select, BGP_INFO_SELECTED);
338b3424 1551 if (new_select)
1552 {
1a392d46
PJ
1553 bgp_info_set_flag (rn, new_select, BGP_INFO_SELECTED);
1554 bgp_info_unset_flag (rn, new_select, BGP_INFO_ATTR_CHANGED);
338b3424 1555 }
1556
1557
fee0f4c6 1558 /* Check each BGP peer. */
1eb8ef25 1559 for (ALL_LIST_ELEMENTS (bgp->peer, node, nnode, peer))
fee0f4c6 1560 {
9eda90ce 1561 bgp_process_announce_selected (peer, new_select, rn, afi, safi);
718e3744 1562 }
1563
1564 /* FIB update. */
1565 if (safi == SAFI_UNICAST && ! bgp->name &&
1566 ! bgp_option_check (BGP_OPT_NO_FIB))
1567 {
1568 if (new_select
1569 && new_select->type == ZEBRA_ROUTE_BGP
1570 && new_select->sub_type == BGP_ROUTE_NORMAL)
1571 bgp_zebra_announce (p, new_select, bgp);
1572 else
1573 {
1574 /* Withdraw the route from the kernel. */
1575 if (old_select
1576 && old_select->type == ZEBRA_ROUTE_BGP
1577 && old_select->sub_type == BGP_ROUTE_NORMAL)
1578 bgp_zebra_withdraw (p, old_select);
1579 }
1580 }
b40d939b 1581
1582 /* Reap old select bgp_info, it it has been removed */
1583 if (old_select && CHECK_FLAG (old_select->flags, BGP_INFO_REMOVED))
1584 bgp_info_reap (rn, old_select);
1585
200df115 1586 UNSET_FLAG (rn->flags, BGP_NODE_PROCESS_SCHEDULED);
1587 return WQ_SUCCESS;
718e3744 1588}
1589
200df115 1590static void
0fb58d5d 1591bgp_processq_del (struct work_queue *wq, void *data)
200df115 1592{
0fb58d5d 1593 struct bgp_process_queue *pq = data;
228da428 1594 struct bgp_table *table = pq->rn->table;
0fb58d5d 1595
228da428 1596 bgp_unlock (pq->bgp);
200df115 1597 bgp_unlock_node (pq->rn);
228da428 1598 bgp_table_unlock (table);
200df115 1599 XFREE (MTYPE_BGP_PROCESS_QUEUE, pq);
1600}
1601
1602static void
1603bgp_process_queue_init (void)
1604{
1605 bm->process_main_queue
1606 = work_queue_new (bm->master, "process_main_queue");
1607 bm->process_rsclient_queue
1608 = work_queue_new (bm->master, "process_rsclient_queue");
1609
1610 if ( !(bm->process_main_queue && bm->process_rsclient_queue) )
1611 {
1612 zlog_err ("%s: Failed to allocate work queue", __func__);
1613 exit (1);
1614 }
1615
1616 bm->process_main_queue->spec.workfunc = &bgp_process_main;
200df115 1617 bm->process_main_queue->spec.del_item_data = &bgp_processq_del;
838bbde0
PJ
1618 bm->process_main_queue->spec.max_retries = 0;
1619 bm->process_main_queue->spec.hold = 50;
1620
1621 memcpy (bm->process_rsclient_queue, bm->process_main_queue,
1622 sizeof (struct work_queue *));
1623 bm->process_rsclient_queue->spec.workfunc = &bgp_process_rsclient;
200df115 1624}
1625
1626void
fee0f4c6 1627bgp_process (struct bgp *bgp, struct bgp_node *rn, afi_t afi, safi_t safi)
1628{
200df115 1629 struct bgp_process_queue *pqnode;
1630
1631 /* already scheduled for processing? */
1632 if (CHECK_FLAG (rn->flags, BGP_NODE_PROCESS_SCHEDULED))
1633 return;
1634
1635 if ( (bm->process_main_queue == NULL) ||
1636 (bm->process_rsclient_queue == NULL) )
1637 bgp_process_queue_init ();
1638
1639 pqnode = XCALLOC (MTYPE_BGP_PROCESS_QUEUE,
1640 sizeof (struct bgp_process_queue));
1641 if (!pqnode)
1642 return;
228da428
CC
1643
1644 /* all unlocked in bgp_processq_del */
1645 bgp_table_lock (rn->table);
1646 pqnode->rn = bgp_lock_node (rn);
200df115 1647 pqnode->bgp = bgp;
228da428 1648 bgp_lock (bgp);
200df115 1649 pqnode->afi = afi;
1650 pqnode->safi = safi;
1651
fee0f4c6 1652 switch (rn->table->type)
1653 {
200df115 1654 case BGP_TABLE_MAIN:
1655 work_queue_add (bm->process_main_queue, pqnode);
1656 break;
1657 case BGP_TABLE_RSCLIENT:
1658 work_queue_add (bm->process_rsclient_queue, pqnode);
1659 break;
fee0f4c6 1660 }
200df115 1661
1662 return;
fee0f4c6 1663}
0a486e5f 1664
94f2b392 1665static int
0a486e5f 1666bgp_maximum_prefix_restart_timer (struct thread *thread)
1667{
1668 struct peer *peer;
1669
1670 peer = THREAD_ARG (thread);
1671 peer->t_pmax_restart = NULL;
1672
1673 if (BGP_DEBUG (events, EVENTS))
1674 zlog_debug ("%s Maximum-prefix restart timer expired, restore peering",
1675 peer->host);
1676
1677 peer_clear (peer);
1678
1679 return 0;
1680}
1681
718e3744 1682int
5228ad27 1683bgp_maximum_prefix_overflow (struct peer *peer, afi_t afi,
1684 safi_t safi, int always)
718e3744 1685{
e0701b79 1686 if (!CHECK_FLAG (peer->af_flags[afi][safi], PEER_FLAG_MAX_PREFIX))
1687 return 0;
1688
1689 if (peer->pcount[afi][safi] > peer->pmax[afi][safi])
718e3744 1690 {
e0701b79 1691 if (CHECK_FLAG (peer->af_sflags[afi][safi], PEER_STATUS_PREFIX_LIMIT)
1692 && ! always)
1693 return 0;
1694
1695 zlog (peer->log, LOG_INFO,
0a486e5f 1696 "%%MAXPFXEXCEED: No. of %s prefix received from %s %ld exceed, "
1697 "limit %ld", afi_safi_print (afi, safi), peer->host,
1698 peer->pcount[afi][safi], peer->pmax[afi][safi]);
e0701b79 1699 SET_FLAG (peer->af_sflags[afi][safi], PEER_STATUS_PREFIX_LIMIT);
1700
1701 if (CHECK_FLAG (peer->af_flags[afi][safi], PEER_FLAG_MAX_PREFIX_WARNING))
1702 return 0;
1703
1704 {
5228ad27 1705 u_int8_t ndata[7];
e0701b79 1706
1707 if (safi == SAFI_MPLS_VPN)
1708 safi = BGP_SAFI_VPNV4;
5228ad27 1709
1710 ndata[0] = (afi >> 8);
1711 ndata[1] = afi;
1712 ndata[2] = safi;
1713 ndata[3] = (peer->pmax[afi][safi] >> 24);
1714 ndata[4] = (peer->pmax[afi][safi] >> 16);
1715 ndata[5] = (peer->pmax[afi][safi] >> 8);
1716 ndata[6] = (peer->pmax[afi][safi]);
e0701b79 1717
1718 SET_FLAG (peer->sflags, PEER_STATUS_PREFIX_OVERFLOW);
1719 bgp_notify_send_with_data (peer, BGP_NOTIFY_CEASE,
1720 BGP_NOTIFY_CEASE_MAX_PREFIX, ndata, 7);
1721 }
0a486e5f 1722
1723 /* restart timer start */
1724 if (peer->pmax_restart[afi][safi])
1725 {
1726 peer->v_pmax_restart = peer->pmax_restart[afi][safi] * 60;
1727
1728 if (BGP_DEBUG (events, EVENTS))
1729 zlog_debug ("%s Maximum-prefix restart timer started for %d secs",
1730 peer->host, peer->v_pmax_restart);
1731
1732 BGP_TIMER_ON (peer->t_pmax_restart, bgp_maximum_prefix_restart_timer,
1733 peer->v_pmax_restart);
1734 }
1735
e0701b79 1736 return 1;
1737 }
1738 else
1739 UNSET_FLAG (peer->af_sflags[afi][safi], PEER_STATUS_PREFIX_LIMIT);
1740
1741 if (peer->pcount[afi][safi] > (peer->pmax[afi][safi] * peer->pmax_threshold[afi][safi] / 100))
1742 {
1743 if (CHECK_FLAG (peer->af_sflags[afi][safi], PEER_STATUS_PREFIX_THRESHOLD)
1744 && ! always)
1745 return 0;
1746
1747 zlog (peer->log, LOG_INFO,
0a486e5f 1748 "%%MAXPFX: No. of %s prefix received from %s reaches %ld, max %ld",
1749 afi_safi_print (afi, safi), peer->host, peer->pcount[afi][safi],
1750 peer->pmax[afi][safi]);
e0701b79 1751 SET_FLAG (peer->af_sflags[afi][safi], PEER_STATUS_PREFIX_THRESHOLD);
718e3744 1752 }
e0701b79 1753 else
1754 UNSET_FLAG (peer->af_sflags[afi][safi], PEER_STATUS_PREFIX_THRESHOLD);
718e3744 1755 return 0;
1756}
1757
b40d939b 1758/* Unconditionally remove the route from the RIB, without taking
1759 * damping into consideration (eg, because the session went down)
1760 */
94f2b392 1761static void
718e3744 1762bgp_rib_remove (struct bgp_node *rn, struct bgp_info *ri, struct peer *peer,
1763 afi_t afi, safi_t safi)
1764{
902212c3 1765 bgp_aggregate_decrement (peer->bgp, &rn->p, ri, afi, safi);
1766
1767 if (!CHECK_FLAG (ri->flags, BGP_INFO_HISTORY))
1768 bgp_info_delete (rn, ri); /* keep historical info */
1769
b40d939b 1770 bgp_process (peer->bgp, rn, afi, safi);
718e3744 1771}
1772
94f2b392 1773static void
718e3744 1774bgp_rib_withdraw (struct bgp_node *rn, struct bgp_info *ri, struct peer *peer,
b40d939b 1775 afi_t afi, safi_t safi)
718e3744 1776{
718e3744 1777 int status = BGP_DAMP_NONE;
1778
b40d939b 1779 /* apply dampening, if result is suppressed, we'll be retaining
1780 * the bgp_info in the RIB for historical reference.
1781 */
1782 if (CHECK_FLAG (peer->bgp->af_flags[afi][safi], BGP_CONFIG_DAMPENING)
1783 && peer_sort (peer) == BGP_PEER_EBGP)
1784 if ( (status = bgp_damp_withdraw (ri, rn, afi, safi, 0))
1785 == BGP_DAMP_SUPPRESSED)
902212c3 1786 {
902212c3 1787 bgp_aggregate_decrement (peer->bgp, &rn->p, ri, afi, safi);
1788 return;
1789 }
1790
1791 bgp_rib_remove (rn, ri, peer, afi, safi);
718e3744 1792}
1793
94f2b392 1794static void
fee0f4c6 1795bgp_update_rsclient (struct peer *rsclient, afi_t afi, safi_t safi,
1796 struct attr *attr, struct peer *peer, struct prefix *p, int type,
1797 int sub_type, struct prefix_rd *prd, u_char *tag)
1798{
1799 struct bgp_node *rn;
1800 struct bgp *bgp;
fb982c25 1801 struct attr new_attr = { 0 };
fee0f4c6 1802 struct attr *attr_new;
1803 struct attr *attr_new2;
1804 struct bgp_info *ri;
1805 struct bgp_info *new;
fd79ac91 1806 const char *reason;
fee0f4c6 1807 char buf[SU_ADDRSTRLEN];
1808
1809 /* Do not insert announces from a rsclient into its own 'bgp_table'. */
1810 if (peer == rsclient)
1811 return;
1812
1813 bgp = peer->bgp;
1814 rn = bgp_afi_node_get (rsclient->rib[afi][safi], afi, safi, p, prd);
1815
1816 /* Check previously received route. */
1817 for (ri = rn->info; ri; ri = ri->next)
1818 if (ri->peer == peer && ri->type == type && ri->sub_type == sub_type)
1819 break;
1820
1821 /* AS path loop check. */
1822 if (aspath_loop_check (attr->aspath, rsclient->as) > peer->allowas_in[afi][safi])
1823 {
1824 reason = "as-path contains our own AS;";
1825 goto filtered;
1826 }
1827
1828 /* Route reflector originator ID check. */
1829 if (attr->flag & ATTR_FLAG_BIT (BGP_ATTR_ORIGINATOR_ID)
fb982c25 1830 && IPV4_ADDR_SAME (&rsclient->remote_id, &attr->extra->originator_id))
fee0f4c6 1831 {
1832 reason = "originator is us;";
1833 goto filtered;
1834 }
fb982c25
PJ
1835
1836 bgp_attr_dup (&new_attr, attr);
fee0f4c6 1837
1838 /* Apply export policy. */
1839 if (CHECK_FLAG(peer->af_flags[afi][safi], PEER_FLAG_RSERVER_CLIENT) &&
1840 bgp_export_modifier (rsclient, peer, p, &new_attr, afi, safi) == RMAP_DENY)
1841 {
1842 reason = "export-policy;";
1843 goto filtered;
1844 }
1845
1846 attr_new2 = bgp_attr_intern (&new_attr);
fb982c25 1847
fee0f4c6 1848 /* Apply import policy. */
1849 if (bgp_import_modifier (rsclient, peer, p, &new_attr, afi, safi) == RMAP_DENY)
1850 {
1851 bgp_attr_unintern (attr_new2);
1852
1853 reason = "import-policy;";
1854 goto filtered;
1855 }
1856
1857 attr_new = bgp_attr_intern (&new_attr);
1858 bgp_attr_unintern (attr_new2);
1859
1860 /* IPv4 unicast next hop check. */
1861 if (afi == AFI_IP && safi == SAFI_UNICAST)
1862 {
1863 /* Next hop must not be 0.0.0.0 nor Class E address. */
1864 if (new_attr.nexthop.s_addr == 0
1865 || ntohl (new_attr.nexthop.s_addr) >= 0xe0000000)
1866 {
1867 bgp_attr_unintern (attr_new);
1868
1869 reason = "martian next-hop;";
1870 goto filtered;
1871 }
1872 }
fb982c25
PJ
1873
1874 /* new_attr isn't passed to any functions after here */
1875 bgp_attr_extra_free (&new_attr);
1876
fee0f4c6 1877 /* If the update is implicit withdraw. */
1878 if (ri)
1879 {
65957886 1880 ri->uptime = bgp_clock ();
fee0f4c6 1881
1882 /* Same attribute comes in. */
16d2e241
PJ
1883 if (!CHECK_FLAG(ri->flags, BGP_INFO_REMOVED)
1884 && attrhash_cmp (ri->attr, attr_new))
fee0f4c6 1885 {
1886
1a392d46 1887 bgp_info_unset_flag (rn, ri, BGP_INFO_ATTR_CHANGED);
fee0f4c6 1888
1889 if (BGP_DEBUG (update, UPDATE_IN))
d2c1f16b 1890 zlog (peer->log, LOG_DEBUG,
fee0f4c6 1891 "%s rcvd %s/%d for RS-client %s...duplicate ignored",
1892 peer->host,
1893 inet_ntop(p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
1894 p->prefixlen, rsclient->host);
1895
228da428
CC
1896 bgp_unlock_node (rn);
1897 bgp_attr_unintern (attr_new);
fee0f4c6 1898
228da428 1899 return;
fee0f4c6 1900 }
1901
16d2e241
PJ
1902 /* Withdraw/Announce before we fully processed the withdraw */
1903 if (CHECK_FLAG(ri->flags, BGP_INFO_REMOVED))
1904 bgp_info_restore (rn, ri);
1905
fee0f4c6 1906 /* Received Logging. */
1907 if (BGP_DEBUG (update, UPDATE_IN))
d2c1f16b 1908 zlog (peer->log, LOG_DEBUG, "%s rcvd %s/%d for RS-client %s",
fee0f4c6 1909 peer->host,
1910 inet_ntop(p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
1911 p->prefixlen, rsclient->host);
1912
1913 /* The attribute is changed. */
1a392d46 1914 bgp_info_set_flag (rn, ri, BGP_INFO_ATTR_CHANGED);
fee0f4c6 1915
1916 /* Update to new attribute. */
1917 bgp_attr_unintern (ri->attr);
1918 ri->attr = attr_new;
1919
1920 /* Update MPLS tag. */
1921 if (safi == SAFI_MPLS_VPN)
fb982c25 1922 memcpy ((bgp_info_extra_get (ri))->tag, tag, 3);
fee0f4c6 1923
1a392d46 1924 bgp_info_set_flag (rn, ri, BGP_INFO_VALID);
fee0f4c6 1925
1926 /* Process change. */
1927 bgp_process (bgp, rn, afi, safi);
1928 bgp_unlock_node (rn);
1929
1930 return;
1931 }
1932
1933 /* Received Logging. */
1934 if (BGP_DEBUG (update, UPDATE_IN))
1935 {
d2c1f16b 1936 zlog (peer->log, LOG_DEBUG, "%s rcvd %s/%d for RS-client %s",
fee0f4c6 1937 peer->host,
1938 inet_ntop(p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
1939 p->prefixlen, rsclient->host);
1940 }
1941
1942 /* Make new BGP info. */
1943 new = bgp_info_new ();
1944 new->type = type;
1945 new->sub_type = sub_type;
1946 new->peer = peer;
1947 new->attr = attr_new;
65957886 1948 new->uptime = bgp_clock ();
fee0f4c6 1949
1950 /* Update MPLS tag. */
1951 if (safi == SAFI_MPLS_VPN)
fb982c25 1952 memcpy ((bgp_info_extra_get (new))->tag, tag, 3);
fee0f4c6 1953
1a392d46 1954 bgp_info_set_flag (rn, new, BGP_INFO_VALID);
fee0f4c6 1955
1956 /* Register new BGP information. */
1957 bgp_info_add (rn, new);
200df115 1958
1959 /* route_node_get lock */
1960 bgp_unlock_node (rn);
1961
fee0f4c6 1962 /* Process change. */
1963 bgp_process (bgp, rn, afi, safi);
fb982c25
PJ
1964
1965 bgp_attr_extra_free (&new_attr);
1966
fee0f4c6 1967 return;
1968
1969 filtered:
1970
1971 /* This BGP update is filtered. Log the reason then update BGP entry. */
1972 if (BGP_DEBUG (update, UPDATE_IN))
d2c1f16b 1973 zlog (peer->log, LOG_DEBUG,
fee0f4c6 1974 "%s rcvd UPDATE about %s/%d -- DENIED for RS-client %s due to: %s",
1975 peer->host,
1976 inet_ntop (p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
1977 p->prefixlen, rsclient->host, reason);
1978
1979 if (ri)
b40d939b 1980 bgp_rib_remove (rn, ri, peer, afi, safi);
fee0f4c6 1981
1982 bgp_unlock_node (rn);
fb982c25
PJ
1983
1984 if (new_attr.extra)
1985 bgp_attr_extra_free (&new_attr);
1986
fee0f4c6 1987 return;
1988}
1989
94f2b392 1990static void
fee0f4c6 1991bgp_withdraw_rsclient (struct peer *rsclient, afi_t afi, safi_t safi,
1992 struct peer *peer, struct prefix *p, int type, int sub_type,
1993 struct prefix_rd *prd, u_char *tag)
228da428 1994{
fee0f4c6 1995 struct bgp_node *rn;
1996 struct bgp_info *ri;
1997 char buf[SU_ADDRSTRLEN];
1998
1999 if (rsclient == peer)
228da428 2000 return;
fee0f4c6 2001
2002 rn = bgp_afi_node_get (rsclient->rib[afi][safi], afi, safi, p, prd);
2003
2004 /* Lookup withdrawn route. */
2005 for (ri = rn->info; ri; ri = ri->next)
2006 if (ri->peer == peer && ri->type == type && ri->sub_type == sub_type)
2007 break;
2008
2009 /* Withdraw specified route from routing table. */
2010 if (ri && ! CHECK_FLAG (ri->flags, BGP_INFO_HISTORY))
b40d939b 2011 bgp_rib_withdraw (rn, ri, peer, afi, safi);
fee0f4c6 2012 else if (BGP_DEBUG (update, UPDATE_IN))
d2c1f16b 2013 zlog (peer->log, LOG_DEBUG,
fee0f4c6 2014 "%s Can't find the route %s/%d", peer->host,
2015 inet_ntop (p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
2016 p->prefixlen);
2017
2018 /* Unlock bgp_node_get() lock. */
228da428
CC
2019 bgp_unlock_node (rn);
2020}
fee0f4c6 2021
94f2b392 2022static int
fee0f4c6 2023bgp_update_main (struct peer *peer, struct prefix *p, struct attr *attr,
718e3744 2024 afi_t afi, safi_t safi, int type, int sub_type,
2025 struct prefix_rd *prd, u_char *tag, int soft_reconfig)
2026{
2027 int ret;
2028 int aspath_loop_count = 0;
2029 struct bgp_node *rn;
2030 struct bgp *bgp;
fb982c25 2031 struct attr new_attr = { 0 };
718e3744 2032 struct attr *attr_new;
2033 struct bgp_info *ri;
2034 struct bgp_info *new;
fd79ac91 2035 const char *reason;
718e3744 2036 char buf[SU_ADDRSTRLEN];
2037
2038 bgp = peer->bgp;
fee0f4c6 2039 rn = bgp_afi_node_get (bgp->rib[afi][safi], afi, safi, p, prd);
fb982c25 2040
718e3744 2041 /* When peer's soft reconfiguration enabled. Record input packet in
2042 Adj-RIBs-In. */
2043 if (CHECK_FLAG (peer->af_flags[afi][safi], PEER_FLAG_SOFT_RECONFIG)
2044 && peer != bgp->peer_self && ! soft_reconfig)
2045 bgp_adj_in_set (rn, peer, attr);
2046
2047 /* Check previously received route. */
2048 for (ri = rn->info; ri; ri = ri->next)
2049 if (ri->peer == peer && ri->type == type && ri->sub_type == sub_type)
2050 break;
2051
2052 /* AS path local-as loop check. */
2053 if (peer->change_local_as)
2054 {
2055 if (! CHECK_FLAG (peer->flags, PEER_FLAG_LOCAL_AS_NO_PREPEND))
2056 aspath_loop_count = 1;
2057
2058 if (aspath_loop_check (attr->aspath, peer->change_local_as) > aspath_loop_count)
2059 {
2060 reason = "as-path contains our own AS;";
2061 goto filtered;
2062 }
2063 }
2064
2065 /* AS path loop check. */
2066 if (aspath_loop_check (attr->aspath, bgp->as) > peer->allowas_in[afi][safi]
2067 || (CHECK_FLAG(bgp->config, BGP_CONFIG_CONFEDERATION)
2068 && aspath_loop_check(attr->aspath, bgp->confed_id)
2069 > peer->allowas_in[afi][safi]))
2070 {
2071 reason = "as-path contains our own AS;";
2072 goto filtered;
2073 }
2074
2075 /* Route reflector originator ID check. */
2076 if (attr->flag & ATTR_FLAG_BIT (BGP_ATTR_ORIGINATOR_ID)
fb982c25 2077 && IPV4_ADDR_SAME (&bgp->router_id, &attr->extra->originator_id))
718e3744 2078 {
2079 reason = "originator is us;";
2080 goto filtered;
2081 }
2082
2083 /* Route reflector cluster ID check. */
2084 if (bgp_cluster_filter (peer, attr))
2085 {
2086 reason = "reflected from the same cluster;";
2087 goto filtered;
2088 }
2089
2090 /* Apply incoming filter. */
2091 if (bgp_input_filter (peer, p, attr, afi, safi) == FILTER_DENY)
2092 {
2093 reason = "filter;";
2094 goto filtered;
2095 }
2096
2097 /* Apply incoming route-map. */
fb982c25 2098 bgp_attr_dup (&new_attr, attr);
718e3744 2099
2100 if (bgp_input_modifier (peer, p, &new_attr, afi, safi) == RMAP_DENY)
2101 {
2102 reason = "route-map;";
2103 goto filtered;
2104 }
2105
2106 /* IPv4 unicast next hop check. */
2107 if (afi == AFI_IP && safi == SAFI_UNICAST)
2108 {
2109 /* If the peer is EBGP and nexthop is not on connected route,
2110 discard it. */
2111 if (peer_sort (peer) == BGP_PEER_EBGP && peer->ttl == 1
2112 && ! bgp_nexthop_check_ebgp (afi, &new_attr)
6ffd2079 2113 && ! CHECK_FLAG (peer->flags, PEER_FLAG_DISABLE_CONNECTED_CHECK))
718e3744 2114 {
2115 reason = "non-connected next-hop;";
2116 goto filtered;
2117 }
2118
2119 /* Next hop must not be 0.0.0.0 nor Class E address. Next hop
2120 must not be my own address. */
2121 if (bgp_nexthop_self (afi, &new_attr)
2122 || new_attr.nexthop.s_addr == 0
2123 || ntohl (new_attr.nexthop.s_addr) >= 0xe0000000)
2124 {
2125 reason = "martian next-hop;";
2126 goto filtered;
2127 }
2128 }
2129
2130 attr_new = bgp_attr_intern (&new_attr);
2131
2132 /* If the update is implicit withdraw. */
2133 if (ri)
2134 {
65957886 2135 ri->uptime = bgp_clock ();
718e3744 2136
2137 /* Same attribute comes in. */
16d2e241
PJ
2138 if (!CHECK_FLAG (ri->flags, BGP_INFO_REMOVED)
2139 && attrhash_cmp (ri->attr, attr_new))
718e3744 2140 {
1a392d46 2141 bgp_info_unset_flag (rn, ri, BGP_INFO_ATTR_CHANGED);
718e3744 2142
2143 if (CHECK_FLAG (bgp->af_flags[afi][safi], BGP_CONFIG_DAMPENING)
2144 && peer_sort (peer) == BGP_PEER_EBGP
2145 && CHECK_FLAG (ri->flags, BGP_INFO_HISTORY))
2146 {
2147 if (BGP_DEBUG (update, UPDATE_IN))
d2c1f16b 2148 zlog (peer->log, LOG_DEBUG, "%s rcvd %s/%d",
718e3744 2149 peer->host,
2150 inet_ntop(p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
2151 p->prefixlen);
2152
902212c3 2153 if (bgp_damp_update (ri, rn, afi, safi) != BGP_DAMP_SUPPRESSED)
2154 {
2155 bgp_aggregate_increment (bgp, p, ri, afi, safi);
2156 bgp_process (bgp, rn, afi, safi);
2157 }
718e3744 2158 }
16d2e241 2159 else /* Duplicate - odd */
718e3744 2160 {
2161 if (BGP_DEBUG (update, UPDATE_IN))
d2c1f16b 2162 zlog (peer->log, LOG_DEBUG,
718e3744 2163 "%s rcvd %s/%d...duplicate ignored",
2164 peer->host,
2165 inet_ntop(p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
2166 p->prefixlen);
93406d87 2167
2168 /* graceful restart STALE flag unset. */
2169 if (CHECK_FLAG (ri->flags, BGP_INFO_STALE))
2170 {
1a392d46 2171 bgp_info_unset_flag (rn, ri, BGP_INFO_STALE);
902212c3 2172 bgp_process (bgp, rn, afi, safi);
93406d87 2173 }
718e3744 2174 }
2175
2176 bgp_unlock_node (rn);
2177 bgp_attr_unintern (attr_new);
fb982c25
PJ
2178 bgp_attr_extra_free (&new_attr);
2179
718e3744 2180 return 0;
2181 }
2182
16d2e241
PJ
2183 /* Withdraw/Announce before we fully processed the withdraw */
2184 if (CHECK_FLAG(ri->flags, BGP_INFO_REMOVED))
2185 {
2186 if (BGP_DEBUG (update, UPDATE_IN))
2187 zlog (peer->log, LOG_DEBUG, "%s rcvd %s/%d, flapped quicker than processing",
2188 peer->host,
2189 inet_ntop(p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
2190 p->prefixlen);
2191 bgp_info_restore (rn, ri);
2192 }
2193
718e3744 2194 /* Received Logging. */
2195 if (BGP_DEBUG (update, UPDATE_IN))
d2c1f16b 2196 zlog (peer->log, LOG_DEBUG, "%s rcvd %s/%d",
718e3744 2197 peer->host,
2198 inet_ntop(p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
2199 p->prefixlen);
2200
93406d87 2201 /* graceful restart STALE flag unset. */
2202 if (CHECK_FLAG (ri->flags, BGP_INFO_STALE))
1a392d46 2203 bgp_info_unset_flag (rn, ri, BGP_INFO_STALE);
93406d87 2204
718e3744 2205 /* The attribute is changed. */
1a392d46 2206 bgp_info_set_flag (rn, ri, BGP_INFO_ATTR_CHANGED);
902212c3 2207
2208 /* implicit withdraw, decrement aggregate and pcount here.
2209 * only if update is accepted, they'll increment below.
2210 */
902212c3 2211 bgp_aggregate_decrement (bgp, p, ri, afi, safi);
2212
718e3744 2213 /* Update bgp route dampening information. */
2214 if (CHECK_FLAG (bgp->af_flags[afi][safi], BGP_CONFIG_DAMPENING)
2215 && peer_sort (peer) == BGP_PEER_EBGP)
2216 {
2217 /* This is implicit withdraw so we should update dampening
2218 information. */
2219 if (! CHECK_FLAG (ri->flags, BGP_INFO_HISTORY))
2220 bgp_damp_withdraw (ri, rn, afi, safi, 1);
718e3744 2221 }
2222
718e3744 2223 /* Update to new attribute. */
2224 bgp_attr_unintern (ri->attr);
2225 ri->attr = attr_new;
2226
2227 /* Update MPLS tag. */
2228 if (safi == SAFI_MPLS_VPN)
fb982c25 2229 memcpy ((bgp_info_extra_get (ri))->tag, tag, 3);
718e3744 2230
2231 /* Update bgp route dampening information. */
2232 if (CHECK_FLAG (bgp->af_flags[afi][safi], BGP_CONFIG_DAMPENING)
2233 && peer_sort (peer) == BGP_PEER_EBGP)
2234 {
2235 /* Now we do normal update dampening. */
2236 ret = bgp_damp_update (ri, rn, afi, safi);
2237 if (ret == BGP_DAMP_SUPPRESSED)
2238 {
2239 bgp_unlock_node (rn);
fb982c25 2240 bgp_attr_extra_free (&new_attr);
718e3744 2241 return 0;
2242 }
2243 }
2244
2245 /* Nexthop reachability check. */
2246 if ((afi == AFI_IP || afi == AFI_IP6)
2247 && safi == SAFI_UNICAST
2248 && (peer_sort (peer) == BGP_PEER_IBGP
638b70ba 2249 || peer_sort (peer) == BGP_PEER_CONFED
718e3744 2250 || (peer_sort (peer) == BGP_PEER_EBGP && peer->ttl != 1)
6ffd2079 2251 || CHECK_FLAG (peer->flags, PEER_FLAG_DISABLE_CONNECTED_CHECK)))
718e3744 2252 {
2253 if (bgp_nexthop_lookup (afi, peer, ri, NULL, NULL))
1a392d46 2254 bgp_info_set_flag (rn, ri, BGP_INFO_VALID);
718e3744 2255 else
1a392d46 2256 bgp_info_unset_flag (rn, ri, BGP_INFO_VALID);
718e3744 2257 }
2258 else
1a392d46 2259 bgp_info_set_flag (rn, ri, BGP_INFO_VALID);
718e3744 2260
2261 /* Process change. */
2262 bgp_aggregate_increment (bgp, p, ri, afi, safi);
2263
2264 bgp_process (bgp, rn, afi, safi);
2265 bgp_unlock_node (rn);
fb982c25
PJ
2266 bgp_attr_extra_free (&new_attr);
2267
718e3744 2268 return 0;
2269 }
2270
2271 /* Received Logging. */
2272 if (BGP_DEBUG (update, UPDATE_IN))
2273 {
d2c1f16b 2274 zlog (peer->log, LOG_DEBUG, "%s rcvd %s/%d",
718e3744 2275 peer->host,
2276 inet_ntop(p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
2277 p->prefixlen);
2278 }
2279
718e3744 2280 /* Make new BGP info. */
2281 new = bgp_info_new ();
2282 new->type = type;
2283 new->sub_type = sub_type;
2284 new->peer = peer;
2285 new->attr = attr_new;
65957886 2286 new->uptime = bgp_clock ();
718e3744 2287
2288 /* Update MPLS tag. */
2289 if (safi == SAFI_MPLS_VPN)
fb982c25 2290 memcpy ((bgp_info_extra_get (new))->tag, tag, 3);
718e3744 2291
2292 /* Nexthop reachability check. */
2293 if ((afi == AFI_IP || afi == AFI_IP6)
2294 && safi == SAFI_UNICAST
2295 && (peer_sort (peer) == BGP_PEER_IBGP
638b70ba 2296 || peer_sort (peer) == BGP_PEER_CONFED
718e3744 2297 || (peer_sort (peer) == BGP_PEER_EBGP && peer->ttl != 1)
6ffd2079 2298 || CHECK_FLAG (peer->flags, PEER_FLAG_DISABLE_CONNECTED_CHECK)))
718e3744 2299 {
2300 if (bgp_nexthop_lookup (afi, peer, new, NULL, NULL))
1a392d46 2301 bgp_info_set_flag (rn, new, BGP_INFO_VALID);
718e3744 2302 else
1a392d46 2303 bgp_info_unset_flag (rn, new, BGP_INFO_VALID);
718e3744 2304 }
2305 else
1a392d46 2306 bgp_info_set_flag (rn, new, BGP_INFO_VALID);
718e3744 2307
902212c3 2308 /* Increment prefix */
718e3744 2309 bgp_aggregate_increment (bgp, p, new, afi, safi);
2310
2311 /* Register new BGP information. */
2312 bgp_info_add (rn, new);
200df115 2313
2314 /* route_node_get lock */
2315 bgp_unlock_node (rn);
2316
fb982c25
PJ
2317 bgp_attr_extra_free (&new_attr);
2318
718e3744 2319 /* If maximum prefix count is configured and current prefix
2320 count exeed it. */
e0701b79 2321 if (bgp_maximum_prefix_overflow (peer, afi, safi, 0))
2322 return -1;
718e3744 2323
2324 /* Process change. */
2325 bgp_process (bgp, rn, afi, safi);
2326
2327 return 0;
2328
2329 /* This BGP update is filtered. Log the reason then update BGP
2330 entry. */
2331 filtered:
2332 if (BGP_DEBUG (update, UPDATE_IN))
d2c1f16b 2333 zlog (peer->log, LOG_DEBUG,
718e3744 2334 "%s rcvd UPDATE about %s/%d -- DENIED due to: %s",
2335 peer->host,
2336 inet_ntop (p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
2337 p->prefixlen, reason);
2338
2339 if (ri)
b40d939b 2340 bgp_rib_remove (rn, ri, peer, afi, safi);
718e3744 2341
2342 bgp_unlock_node (rn);
fb982c25
PJ
2343
2344 bgp_attr_extra_free (&new_attr);
2345
718e3744 2346 return 0;
2347}
2348
fee0f4c6 2349int
2350bgp_update (struct peer *peer, struct prefix *p, struct attr *attr,
2351 afi_t afi, safi_t safi, int type, int sub_type,
2352 struct prefix_rd *prd, u_char *tag, int soft_reconfig)
2353{
2354 struct peer *rsclient;
1eb8ef25 2355 struct listnode *node, *nnode;
fee0f4c6 2356 struct bgp *bgp;
2357 int ret;
2358
2359 ret = bgp_update_main (peer, p, attr, afi, safi, type, sub_type, prd, tag,
2360 soft_reconfig);
2361
2362 bgp = peer->bgp;
2363
2364 /* Process the update for each RS-client. */
1eb8ef25 2365 for (ALL_LIST_ELEMENTS (bgp->rsclient, node, nnode, rsclient))
fee0f4c6 2366 {
2367 if (CHECK_FLAG (rsclient->af_flags[afi][safi], PEER_FLAG_RSERVER_CLIENT))
2368 bgp_update_rsclient (rsclient, afi, safi, attr, peer, p, type,
2369 sub_type, prd, tag);
2370 }
2371
2372 return ret;
2373}
2374
718e3744 2375int
2376bgp_withdraw (struct peer *peer, struct prefix *p, struct attr *attr,
94f2b392 2377 afi_t afi, safi_t safi, int type, int sub_type,
2378 struct prefix_rd *prd, u_char *tag)
718e3744 2379{
2380 struct bgp *bgp;
2381 char buf[SU_ADDRSTRLEN];
2382 struct bgp_node *rn;
2383 struct bgp_info *ri;
fee0f4c6 2384 struct peer *rsclient;
1eb8ef25 2385 struct listnode *node, *nnode;
718e3744 2386
2387 bgp = peer->bgp;
2388
fee0f4c6 2389 /* Process the withdraw for each RS-client. */
1eb8ef25 2390 for (ALL_LIST_ELEMENTS (bgp->rsclient, node, nnode, rsclient))
fee0f4c6 2391 {
2392 if (CHECK_FLAG (rsclient->af_flags[afi][safi], PEER_FLAG_RSERVER_CLIENT))
2393 bgp_withdraw_rsclient (rsclient, afi, safi, peer, p, type, sub_type, prd, tag);
2394 }
2395
718e3744 2396 /* Logging. */
2397 if (BGP_DEBUG (update, UPDATE_IN))
d2c1f16b 2398 zlog (peer->log, LOG_DEBUG, "%s rcvd UPDATE about %s/%d -- withdrawn",
718e3744 2399 peer->host,
2400 inet_ntop(p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
2401 p->prefixlen);
2402
2403 /* Lookup node. */
fee0f4c6 2404 rn = bgp_afi_node_get (bgp->rib[afi][safi], afi, safi, p, prd);
718e3744 2405
2406 /* If peer is soft reconfiguration enabled. Record input packet for
2407 further calculation. */
2408 if (CHECK_FLAG (peer->af_flags[afi][safi], PEER_FLAG_SOFT_RECONFIG)
2409 && peer != bgp->peer_self)
2410 bgp_adj_in_unset (rn, peer);
2411
2412 /* Lookup withdrawn route. */
2413 for (ri = rn->info; ri; ri = ri->next)
2414 if (ri->peer == peer && ri->type == type && ri->sub_type == sub_type)
2415 break;
2416
2417 /* Withdraw specified route from routing table. */
2418 if (ri && ! CHECK_FLAG (ri->flags, BGP_INFO_HISTORY))
b40d939b 2419 bgp_rib_withdraw (rn, ri, peer, afi, safi);
718e3744 2420 else if (BGP_DEBUG (update, UPDATE_IN))
d2c1f16b 2421 zlog (peer->log, LOG_DEBUG,
718e3744 2422 "%s Can't find the route %s/%d", peer->host,
2423 inet_ntop (p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
2424 p->prefixlen);
2425
2426 /* Unlock bgp_node_get() lock. */
2427 bgp_unlock_node (rn);
2428
2429 return 0;
2430}
2431\f
2432void
2433bgp_default_originate (struct peer *peer, afi_t afi, safi_t safi, int withdraw)
2434{
2435 struct bgp *bgp;
228da428 2436 struct attr attr = { 0 };
fb982c25 2437 struct aspath *aspath = { 0 };
718e3744 2438 struct prefix p;
2439 struct bgp_info binfo;
2440 struct peer *from;
2441 int ret = RMAP_DENYMATCH;
fb982c25 2442
b2497024 2443 if (!(afi == AFI_IP || afi == AFI_IP6))
fb982c25
PJ
2444 return;
2445
718e3744 2446 bgp = peer->bgp;
2447 from = bgp->peer_self;
fb982c25 2448
718e3744 2449 bgp_attr_default_set (&attr, BGP_ORIGIN_IGP);
2450 aspath = attr.aspath;
2451 attr.local_pref = bgp->default_local_pref;
2452 memcpy (&attr.nexthop, &peer->nexthop.v4, IPV4_MAX_BYTELEN);
2453
2454 if (afi == AFI_IP)
2455 str2prefix ("0.0.0.0/0", &p);
2456#ifdef HAVE_IPV6
2457 else if (afi == AFI_IP6)
2458 {
fb982c25
PJ
2459 struct attr_extra *ae;
2460 attr.extra = NULL;
2461
2462 ae = bgp_attr_extra_get (&attr);
2463 attr.extra = ae;
2464
718e3744 2465 str2prefix ("::/0", &p);
2466
2467 /* IPv6 global nexthop must be included. */
fb982c25 2468 memcpy (&ae->mp_nexthop_global, &peer->nexthop.v6_global,
718e3744 2469 IPV6_MAX_BYTELEN);
fb982c25 2470 ae->mp_nexthop_len = 16;
718e3744 2471
2472 /* If the peer is on shared nextwork and we have link-local
2473 nexthop set it. */
2474 if (peer->shared_network
2475 && !IN6_IS_ADDR_UNSPECIFIED (&peer->nexthop.v6_local))
2476 {
fb982c25 2477 memcpy (&ae->mp_nexthop_local, &peer->nexthop.v6_local,
718e3744 2478 IPV6_MAX_BYTELEN);
fb982c25 2479 ae->mp_nexthop_len = 32;
718e3744 2480 }
2481 }
2482#endif /* HAVE_IPV6 */
718e3744 2483
2484 if (peer->default_rmap[afi][safi].name)
2485 {
2486 binfo.peer = bgp->peer_self;
2487 binfo.attr = &attr;
2488
fee0f4c6 2489 SET_FLAG (bgp->peer_self->rmap_type, PEER_RMAP_TYPE_DEFAULT);
2490
718e3744 2491 ret = route_map_apply (peer->default_rmap[afi][safi].map, &p,
2492 RMAP_BGP, &binfo);
2493
fee0f4c6 2494 bgp->peer_self->rmap_type = 0;
2495
718e3744 2496 if (ret == RMAP_DENYMATCH)
2497 {
2498 bgp_attr_flush (&attr);
2499 withdraw = 1;
2500 }
2501 }
2502
2503 if (withdraw)
2504 {
2505 if (CHECK_FLAG (peer->af_sflags[afi][safi], PEER_STATUS_DEFAULT_ORIGINATE))
2506 bgp_default_withdraw_send (peer, afi, safi);
2507 UNSET_FLAG (peer->af_sflags[afi][safi], PEER_STATUS_DEFAULT_ORIGINATE);
2508 }
2509 else
2510 {
2511 SET_FLAG (peer->af_sflags[afi][safi], PEER_STATUS_DEFAULT_ORIGINATE);
2512 bgp_default_update_send (peer, &attr, afi, safi, from);
2513 }
fb982c25
PJ
2514
2515 bgp_attr_extra_free (&attr);
718e3744 2516 aspath_unintern (aspath);
2517}
2518\f
2519static void
2520bgp_announce_table (struct peer *peer, afi_t afi, safi_t safi,
fee0f4c6 2521 struct bgp_table *table, int rsclient)
718e3744 2522{
2523 struct bgp_node *rn;
2524 struct bgp_info *ri;
228da428 2525 struct attr attr = { 0 };
fb982c25 2526
718e3744 2527 if (! table)
fee0f4c6 2528 table = (rsclient) ? peer->rib[afi][safi] : peer->bgp->rib[afi][safi];
718e3744 2529
2530 if (safi != SAFI_MPLS_VPN
2531 && CHECK_FLAG (peer->af_flags[afi][safi], PEER_FLAG_DEFAULT_ORIGINATE))
2532 bgp_default_originate (peer, afi, safi, 0);
2533
2534 for (rn = bgp_table_top (table); rn; rn = bgp_route_next(rn))
2535 for (ri = rn->info; ri; ri = ri->next)
2536 if (CHECK_FLAG (ri->flags, BGP_INFO_SELECTED) && ri->peer != peer)
2537 {
fee0f4c6 2538 if ( (rsclient) ?
2539 (bgp_announce_check_rsclient (ri, peer, &rn->p, &attr, afi, safi))
2540 : (bgp_announce_check (ri, peer, &rn->p, &attr, afi, safi)))
718e3744 2541 bgp_adj_out_set (rn, peer, &rn->p, &attr, afi, safi, ri);
2542 else
2543 bgp_adj_out_unset (rn, peer, &rn->p, afi, safi);
fb982c25
PJ
2544
2545 bgp_attr_extra_free (&attr);
718e3744 2546 }
2547}
2548
2549void
2550bgp_announce_route (struct peer *peer, afi_t afi, safi_t safi)
2551{
2552 struct bgp_node *rn;
2553 struct bgp_table *table;
2554
2555 if (peer->status != Established)
2556 return;
2557
2558 if (! peer->afc_nego[afi][safi])
2559 return;
2560
2561 /* First update is deferred until ORF or ROUTE-REFRESH is received */
2562 if (CHECK_FLAG (peer->af_sflags[afi][safi], PEER_STATUS_ORF_WAIT_REFRESH))
2563 return;
2564
2565 if (safi != SAFI_MPLS_VPN)
fee0f4c6 2566 bgp_announce_table (peer, afi, safi, NULL, 0);
718e3744 2567 else
2568 for (rn = bgp_table_top (peer->bgp->rib[afi][safi]); rn;
2569 rn = bgp_route_next(rn))
2570 if ((table = (rn->info)) != NULL)
fee0f4c6 2571 bgp_announce_table (peer, afi, safi, table, 0);
2572
2573 if (CHECK_FLAG(peer->af_flags[afi][safi], PEER_FLAG_RSERVER_CLIENT))
2574 bgp_announce_table (peer, afi, safi, NULL, 1);
718e3744 2575}
2576
2577void
2578bgp_announce_route_all (struct peer *peer)
2579{
2580 afi_t afi;
2581 safi_t safi;
2582
2583 for (afi = AFI_IP; afi < AFI_MAX; afi++)
2584 for (safi = SAFI_UNICAST; safi < SAFI_MAX; safi++)
2585 bgp_announce_route (peer, afi, safi);
2586}
2587\f
2588static void
fee0f4c6 2589bgp_soft_reconfig_table_rsclient (struct peer *rsclient, afi_t afi,
2590 safi_t safi, struct bgp_table *table)
2591{
2592 struct bgp_node *rn;
2593 struct bgp_adj_in *ain;
2594
2595 if (! table)
2596 table = rsclient->bgp->rib[afi][safi];
2597
2598 for (rn = bgp_table_top (table); rn; rn = bgp_route_next (rn))
2599 for (ain = rn->adj_in; ain; ain = ain->next)
2600 {
2601 bgp_update_rsclient (rsclient, afi, safi, ain->attr, ain->peer,
2602 &rn->p, ZEBRA_ROUTE_BGP, BGP_ROUTE_NORMAL, NULL, NULL);
2603 }
2604}
2605
2606void
2607bgp_soft_reconfig_rsclient (struct peer *rsclient, afi_t afi, safi_t safi)
2608{
2609 struct bgp_table *table;
2610 struct bgp_node *rn;
2611
2612 if (safi != SAFI_MPLS_VPN)
2613 bgp_soft_reconfig_table_rsclient (rsclient, afi, safi, NULL);
2614
2615 else
2616 for (rn = bgp_table_top (rsclient->bgp->rib[afi][safi]); rn;
2617 rn = bgp_route_next (rn))
2618 if ((table = rn->info) != NULL)
2619 bgp_soft_reconfig_table_rsclient (rsclient, afi, safi, table);
2620}
2621\f
2622static void
718e3744 2623bgp_soft_reconfig_table (struct peer *peer, afi_t afi, safi_t safi,
2624 struct bgp_table *table)
2625{
2626 int ret;
2627 struct bgp_node *rn;
2628 struct bgp_adj_in *ain;
2629
2630 if (! table)
2631 table = peer->bgp->rib[afi][safi];
2632
2633 for (rn = bgp_table_top (table); rn; rn = bgp_route_next (rn))
2634 for (ain = rn->adj_in; ain; ain = ain->next)
2635 {
2636 if (ain->peer == peer)
2637 {
2638 ret = bgp_update (peer, &rn->p, ain->attr, afi, safi,
2639 ZEBRA_ROUTE_BGP, BGP_ROUTE_NORMAL,
2640 NULL, NULL, 1);
2641 if (ret < 0)
2642 {
2643 bgp_unlock_node (rn);
2644 return;
2645 }
2646 continue;
2647 }
2648 }
2649}
2650
2651void
2652bgp_soft_reconfig_in (struct peer *peer, afi_t afi, safi_t safi)
2653{
2654 struct bgp_node *rn;
2655 struct bgp_table *table;
2656
2657 if (peer->status != Established)
2658 return;
2659
2660 if (safi != SAFI_MPLS_VPN)
2661 bgp_soft_reconfig_table (peer, afi, safi, NULL);
2662 else
2663 for (rn = bgp_table_top (peer->bgp->rib[afi][safi]); rn;
2664 rn = bgp_route_next (rn))
2665 if ((table = rn->info) != NULL)
2666 bgp_soft_reconfig_table (peer, afi, safi, table);
2667}
2668\f
228da428
CC
2669
2670struct bgp_clear_node_queue
2671{
2672 struct bgp_node *rn;
2673 enum bgp_clear_route_type purpose;
2674};
2675
200df115 2676static wq_item_status
0fb58d5d 2677bgp_clear_route_node (struct work_queue *wq, void *data)
200df115 2678{
228da428
CC
2679 struct bgp_clear_node_queue *cnq = data;
2680 struct bgp_node *rn = cnq->rn;
64e580a7 2681 struct peer *peer = wq->spec.data;
718e3744 2682 struct bgp_info *ri;
64e580a7
PJ
2683 afi_t afi = rn->table->afi;
2684 safi_t safi = rn->table->safi;
200df115 2685
64e580a7 2686 assert (rn && peer);
200df115 2687
64e580a7 2688 for (ri = rn->info; ri; ri = ri->next)
228da428 2689 if (ri->peer == peer || cnq->purpose == BGP_CLEAR_ROUTE_MY_RSCLIENT)
200df115 2690 {
2691 /* graceful restart STALE flag set. */
64e580a7
PJ
2692 if (CHECK_FLAG (peer->sflags, PEER_STATUS_NSF_WAIT)
2693 && peer->nsf[afi][safi]
200df115 2694 && ! CHECK_FLAG (ri->flags, BGP_INFO_STALE)
1a392d46
PJ
2695 && ! CHECK_FLAG (ri->flags, BGP_INFO_UNUSEABLE))
2696 bgp_info_set_flag (rn, ri, BGP_INFO_STALE);
200df115 2697 else
64e580a7 2698 bgp_rib_remove (rn, ri, peer, afi, safi);
200df115 2699 break;
2700 }
200df115 2701 return WQ_SUCCESS;
2702}
2703
2704static void
0fb58d5d 2705bgp_clear_node_queue_del (struct work_queue *wq, void *data)
200df115 2706{
228da428
CC
2707 struct bgp_clear_node_queue *cnq = data;
2708 struct bgp_node *rn = cnq->rn;
2709 struct bgp_table *table = rn->table;
64e580a7
PJ
2710
2711 bgp_unlock_node (rn);
228da428
CC
2712 bgp_table_unlock (table);
2713 XFREE (MTYPE_BGP_CLEAR_NODE_QUEUE, cnq);
200df115 2714}
2715
2716static void
94f2b392 2717bgp_clear_node_complete (struct work_queue *wq)
200df115 2718{
64e580a7
PJ
2719 struct peer *peer = wq->spec.data;
2720
3e0c78ef 2721 /* Tickle FSM to start moving again */
ca058a30 2722 BGP_EVENT_ADD (peer, Clearing_Completed);
228da428
CC
2723
2724 peer_unlock (peer); /* bgp_clear_route */
200df115 2725}
2726
2727static void
64e580a7 2728bgp_clear_node_queue_init (struct peer *peer)
200df115 2729{
a2943657 2730 char wname[sizeof("clear xxxx:xxxx:xxxx:xxxx:xxxx:xxxx:xxxx:xxxx")];
64e580a7 2731
a2943657 2732 snprintf (wname, sizeof(wname), "clear %s", peer->host);
64e580a7
PJ
2733#undef CLEAR_QUEUE_NAME_LEN
2734
2735 if ( (peer->clear_node_queue = work_queue_new (bm->master, wname)) == NULL)
200df115 2736 {
2737 zlog_err ("%s: Failed to allocate work queue", __func__);
2738 exit (1);
2739 }
64e580a7
PJ
2740 peer->clear_node_queue->spec.hold = 10;
2741 peer->clear_node_queue->spec.workfunc = &bgp_clear_route_node;
2742 peer->clear_node_queue->spec.del_item_data = &bgp_clear_node_queue_del;
2743 peer->clear_node_queue->spec.completion_func = &bgp_clear_node_complete;
2744 peer->clear_node_queue->spec.max_retries = 0;
2745
2746 /* we only 'lock' this peer reference when the queue is actually active */
2747 peer->clear_node_queue->spec.data = peer;
200df115 2748}
718e3744 2749
200df115 2750static void
2751bgp_clear_route_table (struct peer *peer, afi_t afi, safi_t safi,
228da428
CC
2752 struct bgp_table *table, struct peer *rsclient,
2753 enum bgp_clear_route_type purpose)
200df115 2754{
200df115 2755 struct bgp_node *rn;
2756
f2c31acb 2757
718e3744 2758 if (! table)
fee0f4c6 2759 table = (rsclient) ? rsclient->rib[afi][safi] : peer->bgp->rib[afi][safi];
64e580a7 2760
6cf159b9 2761 /* If still no table => afi/safi isn't configured at all or smth. */
2762 if (! table)
2763 return;
65ca75e0
PJ
2764
2765 for (rn = bgp_table_top (table); rn; rn = bgp_route_next (rn))
2766 {
f2c31acb
PJ
2767 struct bgp_info *ri;
2768 struct bgp_adj_in *ain;
2769 struct bgp_adj_out *aout;
2770
65ca75e0
PJ
2771 if (rn->info == NULL)
2772 continue;
f2c31acb
PJ
2773
2774 /* XXX:TODO: This is suboptimal, every non-empty route_node is
2775 * queued for every clearing peer, regardless of whether it is
2776 * relevant to the peer at hand.
2777 *
2778 * Overview: There are 3 different indices which need to be
2779 * scrubbed, potentially, when a peer is removed:
2780 *
2781 * 1 peer's routes visible via the RIB (ie accepted routes)
2782 * 2 peer's routes visible by the (optional) peer's adj-in index
2783 * 3 other routes visible by the peer's adj-out index
2784 *
2785 * 3 there is no hurry in scrubbing, once the struct peer is
2786 * removed from bgp->peer, we could just GC such deleted peer's
2787 * adj-outs at our leisure.
2788 *
2789 * 1 and 2 must be 'scrubbed' in some way, at least made
2790 * invisible via RIB index before peer session is allowed to be
2791 * brought back up. So one needs to know when such a 'search' is
2792 * complete.
2793 *
2794 * Ideally:
2795 *
2796 * - there'd be a single global queue or a single RIB walker
2797 * - rather than tracking which route_nodes still need to be
2798 * examined on a peer basis, we'd track which peers still
2799 * aren't cleared
2800 *
2801 * Given that our per-peer prefix-counts now should be reliable,
2802 * this may actually be achievable. It doesn't seem to be a huge
2803 * problem at this time,
2804 */
2805 for (ri = rn->info; ri; ri = ri->next)
228da428 2806 if (ri->peer == peer || purpose == BGP_CLEAR_ROUTE_MY_RSCLIENT)
f2c31acb 2807 {
228da428
CC
2808 struct bgp_clear_node_queue *cnq;
2809
2810 /* both unlocked in bgp_clear_node_queue_del */
2811 bgp_table_lock (rn->table);
2812 bgp_lock_node (rn);
2813 cnq = XCALLOC (MTYPE_BGP_CLEAR_NODE_QUEUE,
2814 sizeof (struct bgp_clear_node_queue));
2815 cnq->rn = rn;
2816 cnq->purpose = purpose;
2817 work_queue_add (peer->clear_node_queue, cnq);
2818 break;
f2c31acb
PJ
2819 }
2820
2821 for (ain = rn->adj_in; ain; ain = ain->next)
228da428 2822 if (ain->peer == peer || purpose == BGP_CLEAR_ROUTE_MY_RSCLIENT)
f2c31acb
PJ
2823 {
2824 bgp_adj_in_remove (rn, ain);
2825 bgp_unlock_node (rn);
2826 break;
2827 }
2828 for (aout = rn->adj_out; aout; aout = aout->next)
228da428 2829 if (aout->peer == peer || purpose == BGP_CLEAR_ROUTE_MY_RSCLIENT)
f2c31acb
PJ
2830 {
2831 bgp_adj_out_remove (rn, aout, peer, afi, safi);
2832 bgp_unlock_node (rn);
2833 break;
2834 }
65ca75e0
PJ
2835 }
2836 return;
2837}
2838
2839void
228da428
CC
2840bgp_clear_route (struct peer *peer, afi_t afi, safi_t safi,
2841 enum bgp_clear_route_type purpose)
65ca75e0
PJ
2842{
2843 struct bgp_node *rn;
2844 struct bgp_table *table;
2845 struct peer *rsclient;
2846 struct listnode *node, *nnode;
6cf159b9 2847
64e580a7
PJ
2848 if (peer->clear_node_queue == NULL)
2849 bgp_clear_node_queue_init (peer);
200df115 2850
ca058a30
PJ
2851 /* bgp_fsm.c keeps sessions in state Clearing, not transitioning to
2852 * Idle until it receives a Clearing_Completed event. This protects
2853 * against peers which flap faster than we can we clear, which could
2854 * lead to:
64e580a7
PJ
2855 *
2856 * a) race with routes from the new session being installed before
2857 * clear_route_node visits the node (to delete the route of that
2858 * peer)
2859 * b) resource exhaustion, clear_route_node likely leads to an entry
2860 * on the process_main queue. Fast-flapping could cause that queue
2861 * to grow and grow.
200df115 2862 */
ca058a30
PJ
2863 if (!peer->clear_node_queue->thread)
2864 peer_lock (peer); /* bgp_clear_node_complete */
fee0f4c6 2865
228da428 2866 switch (purpose)
fee0f4c6 2867 {
228da428
CC
2868 case BGP_CLEAR_ROUTE_NORMAL:
2869 if (safi != SAFI_MPLS_VPN)
2870 bgp_clear_route_table (peer, afi, safi, NULL, NULL, purpose);
2871 else
2872 for (rn = bgp_table_top (peer->bgp->rib[afi][safi]); rn;
2873 rn = bgp_route_next (rn))
2874 if ((table = rn->info) != NULL)
2875 bgp_clear_route_table (peer, afi, safi, table, NULL, purpose);
2876
2877 for (ALL_LIST_ELEMENTS (peer->bgp->rsclient, node, nnode, rsclient))
2878 if (CHECK_FLAG(rsclient->af_flags[afi][safi],
2879 PEER_FLAG_RSERVER_CLIENT))
2880 bgp_clear_route_table (peer, afi, safi, NULL, rsclient, purpose);
2881 break;
2882
2883 case BGP_CLEAR_ROUTE_MY_RSCLIENT:
2884 bgp_clear_route_table (peer, afi, safi, NULL, peer, purpose);
2885 break;
2886
2887 default:
2888 assert (0);
2889 break;
fee0f4c6 2890 }
65ca75e0 2891
ca058a30 2892 /* If no routes were cleared, nothing was added to workqueue, the
f2c31acb
PJ
2893 * completion function won't be run by workqueue code - call it here.
2894 * XXX: Actually, this assumption doesn't hold, see
2895 * bgp_clear_route_table(), we queue all non-empty nodes.
ca058a30
PJ
2896 *
2897 * Additionally, there is a presumption in FSM that clearing is only
f2c31acb
PJ
2898 * really needed if peer state is Established - peers in
2899 * pre-Established states shouldn't have any route-update state
2900 * associated with them (in or out).
ca058a30 2901 *
f2c31acb
PJ
2902 * We still can get here in pre-Established though, through
2903 * peer_delete -> bgp_fsm_change_status, so this is a useful sanity
2904 * check to ensure the assumption above holds.
ca058a30
PJ
2905 *
2906 * At some future point, this check could be move to the top of the
2907 * function, and do a quick early-return when state is
2908 * pre-Established, avoiding above list and table scans. Once we're
2909 * sure it is safe..
65ca75e0
PJ
2910 */
2911 if (!peer->clear_node_queue->thread)
2912 bgp_clear_node_complete (peer->clear_node_queue);
718e3744 2913}
2914
2915void
2916bgp_clear_route_all (struct peer *peer)
2917{
2918 afi_t afi;
2919 safi_t safi;
2920
2921 for (afi = AFI_IP; afi < AFI_MAX; afi++)
2922 for (safi = SAFI_UNICAST; safi < SAFI_MAX; safi++)
228da428 2923 bgp_clear_route (peer, afi, safi, BGP_CLEAR_ROUTE_NORMAL);
718e3744 2924}
2925
2926void
2927bgp_clear_adj_in (struct peer *peer, afi_t afi, safi_t safi)
2928{
2929 struct bgp_table *table;
2930 struct bgp_node *rn;
2931 struct bgp_adj_in *ain;
2932
2933 table = peer->bgp->rib[afi][safi];
2934
2935 for (rn = bgp_table_top (table); rn; rn = bgp_route_next (rn))
2936 for (ain = rn->adj_in; ain ; ain = ain->next)
2937 if (ain->peer == peer)
2938 {
2939 bgp_adj_in_remove (rn, ain);
2940 bgp_unlock_node (rn);
2941 break;
2942 }
2943}
93406d87 2944
2945void
2946bgp_clear_stale_route (struct peer *peer, afi_t afi, safi_t safi)
2947{
2948 struct bgp_node *rn;
2949 struct bgp_info *ri;
2950 struct bgp_table *table;
2951
2952 table = peer->bgp->rib[afi][safi];
2953
2954 for (rn = bgp_table_top (table); rn; rn = bgp_route_next (rn))
2955 {
2956 for (ri = rn->info; ri; ri = ri->next)
2957 if (ri->peer == peer)
2958 {
2959 if (CHECK_FLAG (ri->flags, BGP_INFO_STALE))
2960 bgp_rib_remove (rn, ri, peer, afi, safi);
2961 break;
2962 }
2963 }
2964}
718e3744 2965\f
2966/* Delete all kernel routes. */
2967void
66e5cd87 2968bgp_cleanup_routes (void)
718e3744 2969{
2970 struct bgp *bgp;
1eb8ef25 2971 struct listnode *node, *nnode;
718e3744 2972 struct bgp_node *rn;
2973 struct bgp_table *table;
2974 struct bgp_info *ri;
2975
1eb8ef25 2976 for (ALL_LIST_ELEMENTS (bm->bgp, node, nnode, bgp))
718e3744 2977 {
2978 table = bgp->rib[AFI_IP][SAFI_UNICAST];
2979
2980 for (rn = bgp_table_top (table); rn; rn = bgp_route_next (rn))
2981 for (ri = rn->info; ri; ri = ri->next)
2982 if (CHECK_FLAG (ri->flags, BGP_INFO_SELECTED)
2983 && ri->type == ZEBRA_ROUTE_BGP
2984 && ri->sub_type == BGP_ROUTE_NORMAL)
2985 bgp_zebra_withdraw (&rn->p, ri);
2986
2987 table = bgp->rib[AFI_IP6][SAFI_UNICAST];
2988
2989 for (rn = bgp_table_top (table); rn; rn = bgp_route_next (rn))
2990 for (ri = rn->info; ri; ri = ri->next)
2991 if (CHECK_FLAG (ri->flags, BGP_INFO_SELECTED)
2992 && ri->type == ZEBRA_ROUTE_BGP
2993 && ri->sub_type == BGP_ROUTE_NORMAL)
2994 bgp_zebra_withdraw (&rn->p, ri);
2995 }
2996}
2997
2998void
66e5cd87 2999bgp_reset (void)
718e3744 3000{
3001 vty_reset ();
3002 bgp_zclient_reset ();
3003 access_list_reset ();
3004 prefix_list_reset ();
3005}
3006\f
3007/* Parse NLRI stream. Withdraw NLRI is recognized by NULL attr
3008 value. */
3009int
3010bgp_nlri_parse (struct peer *peer, struct attr *attr, struct bgp_nlri *packet)
3011{
3012 u_char *pnt;
3013 u_char *lim;
3014 struct prefix p;
3015 int psize;
3016 int ret;
3017
3018 /* Check peer status. */
3019 if (peer->status != Established)
3020 return 0;
3021
3022 pnt = packet->nlri;
3023 lim = pnt + packet->length;
3024
3025 for (; pnt < lim; pnt += psize)
3026 {
3027 /* Clear prefix structure. */
3028 memset (&p, 0, sizeof (struct prefix));
3029
3030 /* Fetch prefix length. */
3031 p.prefixlen = *pnt++;
3032 p.family = afi2family (packet->afi);
3033
3034 /* Already checked in nlri_sanity_check(). We do double check
3035 here. */
3036 if ((packet->afi == AFI_IP && p.prefixlen > 32)
3037 || (packet->afi == AFI_IP6 && p.prefixlen > 128))
3038 return -1;
3039
3040 /* Packet size overflow check. */
3041 psize = PSIZE (p.prefixlen);
3042
3043 /* When packet overflow occur return immediately. */
3044 if (pnt + psize > lim)
3045 return -1;
3046
3047 /* Fetch prefix from NLRI packet. */
3048 memcpy (&p.u.prefix, pnt, psize);
3049
3050 /* Check address. */
3051 if (packet->afi == AFI_IP && packet->safi == SAFI_UNICAST)
3052 {
3053 if (IN_CLASSD (ntohl (p.u.prefix4.s_addr)))
3054 {
f5ba3874 3055 /*
3056 * From draft-ietf-idr-bgp4-22, Section 6.3:
3057 * If a BGP router receives an UPDATE message with a
3058 * semantically incorrect NLRI field, in which a prefix is
3059 * semantically incorrect (eg. an unexpected multicast IP
3060 * address), it should ignore the prefix.
3061 */
718e3744 3062 zlog (peer->log, LOG_ERR,
3063 "IPv4 unicast NLRI is multicast address %s",
3064 inet_ntoa (p.u.prefix4));
f5ba3874 3065
718e3744 3066 return -1;
3067 }
3068 }
3069
3070#ifdef HAVE_IPV6
3071 /* Check address. */
3072 if (packet->afi == AFI_IP6 && packet->safi == SAFI_UNICAST)
3073 {
3074 if (IN6_IS_ADDR_LINKLOCAL (&p.u.prefix6))
3075 {
3076 char buf[BUFSIZ];
3077
3078 zlog (peer->log, LOG_WARNING,
3079 "IPv6 link-local NLRI received %s ignore this NLRI",
3080 inet_ntop (AF_INET6, &p.u.prefix6, buf, BUFSIZ));
3081
3082 continue;
3083 }
3084 }
3085#endif /* HAVE_IPV6 */
3086
3087 /* Normal process. */
3088 if (attr)
3089 ret = bgp_update (peer, &p, attr, packet->afi, packet->safi,
3090 ZEBRA_ROUTE_BGP, BGP_ROUTE_NORMAL, NULL, NULL, 0);
3091 else
3092 ret = bgp_withdraw (peer, &p, attr, packet->afi, packet->safi,
3093 ZEBRA_ROUTE_BGP, BGP_ROUTE_NORMAL, NULL, NULL);
3094
3095 /* Address family configuration mismatch or maximum-prefix count
3096 overflow. */
3097 if (ret < 0)
3098 return -1;
3099 }
3100
3101 /* Packet length consistency check. */
3102 if (pnt != lim)
3103 return -1;
3104
3105 return 0;
3106}
3107
3108/* NLRI encode syntax check routine. */
3109int
3110bgp_nlri_sanity_check (struct peer *peer, int afi, u_char *pnt,
3111 bgp_size_t length)
3112{
3113 u_char *end;
3114 u_char prefixlen;
3115 int psize;
3116
3117 end = pnt + length;
3118
3119 /* RFC1771 6.3 The NLRI field in the UPDATE message is checked for
3120 syntactic validity. If the field is syntactically incorrect,
3121 then the Error Subcode is set to Invalid Network Field. */
3122
3123 while (pnt < end)
3124 {
3125 prefixlen = *pnt++;
3126
3127 /* Prefix length check. */
3128 if ((afi == AFI_IP && prefixlen > 32)
3129 || (afi == AFI_IP6 && prefixlen > 128))
3130 {
3131 plog_err (peer->log,
3132 "%s [Error] Update packet error (wrong prefix length %d)",
3133 peer->host, prefixlen);
3134 bgp_notify_send (peer, BGP_NOTIFY_UPDATE_ERR,
3135 BGP_NOTIFY_UPDATE_INVAL_NETWORK);
3136 return -1;
3137 }
3138
3139 /* Packet size overflow check. */
3140 psize = PSIZE (prefixlen);
3141
3142 if (pnt + psize > end)
3143 {
3144 plog_err (peer->log,
3145 "%s [Error] Update packet error"
3146 " (prefix data overflow prefix size is %d)",
3147 peer->host, psize);
3148 bgp_notify_send (peer, BGP_NOTIFY_UPDATE_ERR,
3149 BGP_NOTIFY_UPDATE_INVAL_NETWORK);
3150 return -1;
3151 }
3152
3153 pnt += psize;
3154 }
3155
3156 /* Packet length consistency check. */
3157 if (pnt != end)
3158 {
3159 plog_err (peer->log,
3160 "%s [Error] Update packet error"
3161 " (prefix length mismatch with total length)",
3162 peer->host);
3163 bgp_notify_send (peer, BGP_NOTIFY_UPDATE_ERR,
3164 BGP_NOTIFY_UPDATE_INVAL_NETWORK);
3165 return -1;
3166 }
3167 return 0;
3168}
3169\f
94f2b392 3170static struct bgp_static *
66e5cd87 3171bgp_static_new (void)
718e3744 3172{
393deb9b 3173 return XCALLOC (MTYPE_BGP_STATIC, sizeof (struct bgp_static));
718e3744 3174}
3175
94f2b392 3176static void
718e3744 3177bgp_static_free (struct bgp_static *bgp_static)
3178{
3179 if (bgp_static->rmap.name)
3180 free (bgp_static->rmap.name);
3181 XFREE (MTYPE_BGP_STATIC, bgp_static);
3182}
3183
94f2b392 3184static void
fee0f4c6 3185bgp_static_withdraw_rsclient (struct bgp *bgp, struct peer *rsclient,
3186 struct prefix *p, afi_t afi, safi_t safi)
3187{
3188 struct bgp_node *rn;
3189 struct bgp_info *ri;
3190
3191 rn = bgp_afi_node_get (rsclient->rib[afi][safi], afi, safi, p, NULL);
3192
3193 /* Check selected route and self inserted route. */
3194 for (ri = rn->info; ri; ri = ri->next)
3195 if (ri->peer == bgp->peer_self
3196 && ri->type == ZEBRA_ROUTE_BGP
3197 && ri->sub_type == BGP_ROUTE_STATIC)
3198 break;
3199
3200 /* Withdraw static BGP route from routing table. */
3201 if (ri)
3202 {
fee0f4c6 3203 bgp_info_delete (rn, ri);
1a392d46 3204 bgp_process (bgp, rn, afi, safi);
fee0f4c6 3205 }
3206
3207 /* Unlock bgp_node_lookup. */
3208 bgp_unlock_node (rn);
3209}
3210
94f2b392 3211static void
fee0f4c6 3212bgp_static_update_rsclient (struct peer *rsclient, struct prefix *p,
fb982c25
PJ
3213 struct bgp_static *bgp_static,
3214 afi_t afi, safi_t safi)
fee0f4c6 3215{
3216 struct bgp_node *rn;
3217 struct bgp_info *ri;
3218 struct bgp_info *new;
3219 struct bgp_info info;
fee0f4c6 3220 struct attr *attr_new;
fb982c25
PJ
3221 struct attr attr = {0 };
3222 struct attr new_attr = { .extra = 0 };
fee0f4c6 3223 struct bgp *bgp;
3224 int ret;
3225 char buf[SU_ADDRSTRLEN];
3226
3227 bgp = rsclient->bgp;
3228
06e110f9
PJ
3229 assert (bgp_static);
3230 if (!bgp_static)
3231 return;
3232
fee0f4c6 3233 rn = bgp_afi_node_get (rsclient->rib[afi][safi], afi, safi, p, NULL);
3234
3235 bgp_attr_default_set (&attr, BGP_ORIGIN_IGP);
06e110f9
PJ
3236
3237 attr.nexthop = bgp_static->igpnexthop;
3238 attr.med = bgp_static->igpmetric;
3239 attr.flag |= ATTR_FLAG_BIT (BGP_ATTR_MULTI_EXIT_DISC);
41367172
PJ
3240
3241 if (bgp_static->ttl)
3242 {
3243 attr.flag |= ATTR_FLAG_BIT (BGP_ATTR_AS_PATHLIMIT);
3244 attr.flag |= ATTR_FLAG_BIT (BGP_ATTR_ATOMIC_AGGREGATE);
3245 attr.pathlimit.as = 0;
3246 attr.pathlimit.ttl = bgp_static->ttl;
3247 }
3248
3249 if (bgp_static->atomic)
3250 attr.flag |= ATTR_FLAG_BIT (BGP_ATTR_ATOMIC_AGGREGATE);
3251
fee0f4c6 3252 /* Apply network route-map for export to this rsclient. */
3253 if (bgp_static->rmap.name)
3254 {
fb982c25 3255 struct attr attr_tmp = attr;
fee0f4c6 3256 info.peer = rsclient;
fb982c25
PJ
3257 info.attr = &attr_tmp;
3258
fee0f4c6 3259 SET_FLAG (rsclient->rmap_type, PEER_RMAP_TYPE_EXPORT);
3260 SET_FLAG (rsclient->rmap_type, PEER_RMAP_TYPE_NETWORK);
3261
3262 ret = route_map_apply (bgp_static->rmap.map, p, RMAP_BGP, &info);
3263
3264 rsclient->rmap_type = 0;
3265
3266 if (ret == RMAP_DENYMATCH)
3267 {
3268 /* Free uninterned attribute. */
fb982c25 3269 bgp_attr_flush (&attr_tmp);
fee0f4c6 3270
3271 /* Unintern original. */
3272 aspath_unintern (attr.aspath);
3273 bgp_static_withdraw_rsclient (bgp, rsclient, p, afi, safi);
fb982c25
PJ
3274 bgp_attr_extra_free (&attr);
3275
fee0f4c6 3276 return;
3277 }
fb982c25 3278 attr_new = bgp_attr_intern (&attr_tmp);
fee0f4c6 3279 }
3280 else
3281 attr_new = bgp_attr_intern (&attr);
fb982c25 3282
fee0f4c6 3283 new_attr = *attr_new;
fb982c25 3284
fee0f4c6 3285 SET_FLAG (bgp->peer_self->rmap_type, PEER_RMAP_TYPE_NETWORK);
3286
fb982c25
PJ
3287 if (bgp_import_modifier (rsclient, bgp->peer_self, p, &new_attr, afi, safi)
3288 == RMAP_DENY)
3289 {
fee0f4c6 3290 /* This BGP update is filtered. Log the reason then update BGP entry. */
3291 if (BGP_DEBUG (update, UPDATE_IN))
d2c1f16b 3292 zlog (rsclient->log, LOG_DEBUG,
fee0f4c6 3293 "Static UPDATE about %s/%d -- DENIED for RS-client %s due to: import-policy",
3294 inet_ntop (p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
3295 p->prefixlen, rsclient->host);
3296
3297 bgp->peer_self->rmap_type = 0;
3298
3299 bgp_attr_unintern (attr_new);
3300 aspath_unintern (attr.aspath);
fb982c25 3301 bgp_attr_extra_free (&attr);
fee0f4c6 3302
3303 bgp_static_withdraw_rsclient (bgp, rsclient, p, afi, safi);
3304
3305 return;
fb982c25 3306 }
fee0f4c6 3307
3308 bgp->peer_self->rmap_type = 0;
3309
3310 bgp_attr_unintern (attr_new);
3311 attr_new = bgp_attr_intern (&new_attr);
3312
3313 for (ri = rn->info; ri; ri = ri->next)
3314 if (ri->peer == bgp->peer_self && ri->type == ZEBRA_ROUTE_BGP
3315 && ri->sub_type == BGP_ROUTE_STATIC)
3316 break;
3317
3318 if (ri)
3319 {
8d45210e
AS
3320 if (attrhash_cmp (ri->attr, attr_new) &&
3321 !CHECK_FLAG(ri->flags, BGP_INFO_REMOVED))
fee0f4c6 3322 {
3323 bgp_unlock_node (rn);
3324 bgp_attr_unintern (attr_new);
3325 aspath_unintern (attr.aspath);
fb982c25 3326 bgp_attr_extra_free (&attr);
fee0f4c6 3327 return;
3328 }
3329 else
3330 {
3331 /* The attribute is changed. */
1a392d46 3332 bgp_info_set_flag (rn, ri, BGP_INFO_ATTR_CHANGED);
fee0f4c6 3333
3334 /* Rewrite BGP route information. */
8d45210e
AS
3335 if (CHECK_FLAG(ri->flags, BGP_INFO_REMOVED))
3336 bgp_info_restore(rn, ri);
fee0f4c6 3337 bgp_attr_unintern (ri->attr);
3338 ri->attr = attr_new;
65957886 3339 ri->uptime = bgp_clock ();
fee0f4c6 3340
3341 /* Process change. */
3342 bgp_process (bgp, rn, afi, safi);
3343 bgp_unlock_node (rn);
3344 aspath_unintern (attr.aspath);
fb982c25 3345 bgp_attr_extra_free (&attr);
fee0f4c6 3346 return;
fb982c25 3347 }
fee0f4c6 3348 }
fb982c25 3349
fee0f4c6 3350 /* Make new BGP info. */
3351 new = bgp_info_new ();
3352 new->type = ZEBRA_ROUTE_BGP;
3353 new->sub_type = BGP_ROUTE_STATIC;
3354 new->peer = bgp->peer_self;
3355 SET_FLAG (new->flags, BGP_INFO_VALID);
3356 new->attr = attr_new;
65957886 3357 new->uptime = bgp_clock ();
fee0f4c6 3358
3359 /* Register new BGP information. */
3360 bgp_info_add (rn, new);
200df115 3361
3362 /* route_node_get lock */
3363 bgp_unlock_node (rn);
3364
fee0f4c6 3365 /* Process change. */
3366 bgp_process (bgp, rn, afi, safi);
3367
3368 /* Unintern original. */
3369 aspath_unintern (attr.aspath);
fb982c25 3370 bgp_attr_extra_free (&attr);
fee0f4c6 3371}
3372
94f2b392 3373static void
fee0f4c6 3374bgp_static_update_main (struct bgp *bgp, struct prefix *p,
718e3744 3375 struct bgp_static *bgp_static, afi_t afi, safi_t safi)
3376{
3377 struct bgp_node *rn;
3378 struct bgp_info *ri;
3379 struct bgp_info *new;
3380 struct bgp_info info;
fb982c25 3381 struct attr attr = { 0 };
718e3744 3382 struct attr *attr_new;
3383 int ret;
3384
dd8103a9
PJ
3385 assert (bgp_static);
3386 if (!bgp_static)
3387 return;
3388
fee0f4c6 3389 rn = bgp_afi_node_get (bgp->rib[afi][safi], afi, safi, p, NULL);
718e3744 3390
3391 bgp_attr_default_set (&attr, BGP_ORIGIN_IGP);
dd8103a9
PJ
3392
3393 attr.nexthop = bgp_static->igpnexthop;
3394 attr.med = bgp_static->igpmetric;
3395 attr.flag |= ATTR_FLAG_BIT (BGP_ATTR_MULTI_EXIT_DISC);
718e3744 3396
41367172
PJ
3397 if (bgp_static->ttl)
3398 {
3399 attr.flag |= ATTR_FLAG_BIT (BGP_ATTR_AS_PATHLIMIT);
3400 attr.flag |= ATTR_FLAG_BIT (BGP_ATTR_ATOMIC_AGGREGATE);
3401 attr.pathlimit.as = 0;
3402 attr.pathlimit.ttl = bgp_static->ttl;
3403 }
3404
3405 if (bgp_static->atomic)
3406 attr.flag |= ATTR_FLAG_BIT (BGP_ATTR_ATOMIC_AGGREGATE);
3407
718e3744 3408 /* Apply route-map. */
3409 if (bgp_static->rmap.name)
3410 {
fb982c25 3411 struct attr attr_tmp = attr;
718e3744 3412 info.peer = bgp->peer_self;
286e1e71 3413 info.attr = &attr_tmp;
718e3744 3414
fee0f4c6 3415 SET_FLAG (bgp->peer_self->rmap_type, PEER_RMAP_TYPE_NETWORK);
3416
718e3744 3417 ret = route_map_apply (bgp_static->rmap.map, p, RMAP_BGP, &info);
286e1e71 3418
fee0f4c6 3419 bgp->peer_self->rmap_type = 0;
3420
718e3744 3421 if (ret == RMAP_DENYMATCH)
3422 {
3423 /* Free uninterned attribute. */
286e1e71 3424 bgp_attr_flush (&attr_tmp);
718e3744 3425
3426 /* Unintern original. */
3427 aspath_unintern (attr.aspath);
fb982c25 3428 bgp_attr_extra_free (&attr);
718e3744 3429 bgp_static_withdraw (bgp, p, afi, safi);
3430 return;
3431 }
286e1e71 3432 attr_new = bgp_attr_intern (&attr_tmp);
718e3744 3433 }
286e1e71 3434 else
3435 attr_new = bgp_attr_intern (&attr);
718e3744 3436
3437 for (ri = rn->info; ri; ri = ri->next)
3438 if (ri->peer == bgp->peer_self && ri->type == ZEBRA_ROUTE_BGP
3439 && ri->sub_type == BGP_ROUTE_STATIC)
3440 break;
3441
3442 if (ri)
3443 {
8d45210e
AS
3444 if (attrhash_cmp (ri->attr, attr_new) &&
3445 !CHECK_FLAG(ri->flags, BGP_INFO_REMOVED))
718e3744 3446 {
3447 bgp_unlock_node (rn);
3448 bgp_attr_unintern (attr_new);
3449 aspath_unintern (attr.aspath);
fb982c25 3450 bgp_attr_extra_free (&attr);
718e3744 3451 return;
3452 }
3453 else
3454 {
3455 /* The attribute is changed. */
1a392d46 3456 bgp_info_set_flag (rn, ri, BGP_INFO_ATTR_CHANGED);
718e3744 3457
3458 /* Rewrite BGP route information. */
8d45210e
AS
3459 if (CHECK_FLAG(ri->flags, BGP_INFO_REMOVED))
3460 bgp_info_restore(rn, ri);
3461 else
3462 bgp_aggregate_decrement (bgp, p, ri, afi, safi);
718e3744 3463 bgp_attr_unintern (ri->attr);
3464 ri->attr = attr_new;
65957886 3465 ri->uptime = bgp_clock ();
718e3744 3466
3467 /* Process change. */
3468 bgp_aggregate_increment (bgp, p, ri, afi, safi);
3469 bgp_process (bgp, rn, afi, safi);
3470 bgp_unlock_node (rn);
3471 aspath_unintern (attr.aspath);
fb982c25 3472 bgp_attr_extra_free (&attr);
718e3744 3473 return;
3474 }
3475 }
3476
3477 /* Make new BGP info. */
3478 new = bgp_info_new ();
3479 new->type = ZEBRA_ROUTE_BGP;
3480 new->sub_type = BGP_ROUTE_STATIC;
3481 new->peer = bgp->peer_self;
3482 SET_FLAG (new->flags, BGP_INFO_VALID);
3483 new->attr = attr_new;
65957886 3484 new->uptime = bgp_clock ();
718e3744 3485
3486 /* Aggregate address increment. */
3487 bgp_aggregate_increment (bgp, p, new, afi, safi);
3488
3489 /* Register new BGP information. */
3490 bgp_info_add (rn, new);
200df115 3491
3492 /* route_node_get lock */
3493 bgp_unlock_node (rn);
3494
718e3744 3495 /* Process change. */
3496 bgp_process (bgp, rn, afi, safi);
3497
3498 /* Unintern original. */
3499 aspath_unintern (attr.aspath);
fb982c25 3500 bgp_attr_extra_free (&attr);
718e3744 3501}
3502
fee0f4c6 3503void
3504bgp_static_update (struct bgp *bgp, struct prefix *p,
3505 struct bgp_static *bgp_static, afi_t afi, safi_t safi)
3506{
3507 struct peer *rsclient;
1eb8ef25 3508 struct listnode *node, *nnode;
fee0f4c6 3509
3510 bgp_static_update_main (bgp, p, bgp_static, afi, safi);
3511
1eb8ef25 3512 for (ALL_LIST_ELEMENTS (bgp->rsclient, node, nnode, rsclient))
fee0f4c6 3513 {
da5b30f6
PJ
3514 if (CHECK_FLAG (rsclient->af_flags[afi][safi], PEER_FLAG_RSERVER_CLIENT))
3515 bgp_static_update_rsclient (rsclient, p, bgp_static, afi, safi);
fee0f4c6 3516 }
3517}
3518
94f2b392 3519static void
4c9641ba
ML
3520bgp_static_update_vpnv4 (struct bgp *bgp, struct prefix *p, afi_t afi,
3521 safi_t safi, struct prefix_rd *prd, u_char *tag)
718e3744 3522{
3523 struct bgp_node *rn;
3524 struct bgp_info *new;
fb982c25 3525
fee0f4c6 3526 rn = bgp_afi_node_get (bgp->rib[afi][safi], afi, safi, p, prd);
718e3744 3527
3528 /* Make new BGP info. */
3529 new = bgp_info_new ();
3530 new->type = ZEBRA_ROUTE_BGP;
3531 new->sub_type = BGP_ROUTE_STATIC;
3532 new->peer = bgp->peer_self;
3533 new->attr = bgp_attr_default_intern (BGP_ORIGIN_IGP);
3534 SET_FLAG (new->flags, BGP_INFO_VALID);
65957886 3535 new->uptime = bgp_clock ();
fb982c25
PJ
3536 new->extra = bgp_info_extra_new();
3537 memcpy (new->extra->tag, tag, 3);
718e3744 3538
3539 /* Aggregate address increment. */
200df115 3540 bgp_aggregate_increment (bgp, p, new, afi, safi);
718e3744 3541
3542 /* Register new BGP information. */
200df115 3543 bgp_info_add (rn, new);
718e3744 3544
200df115 3545 /* route_node_get lock */
3546 bgp_unlock_node (rn);
3547
718e3744 3548 /* Process change. */
3549 bgp_process (bgp, rn, afi, safi);
3550}
3551
3552void
3553bgp_static_withdraw (struct bgp *bgp, struct prefix *p, afi_t afi,
3554 safi_t safi)
3555{
3556 struct bgp_node *rn;
3557 struct bgp_info *ri;
3558
fee0f4c6 3559 rn = bgp_afi_node_get (bgp->rib[afi][safi], afi, safi, p, NULL);
718e3744 3560
3561 /* Check selected route and self inserted route. */
3562 for (ri = rn->info; ri; ri = ri->next)
3563 if (ri->peer == bgp->peer_self
3564 && ri->type == ZEBRA_ROUTE_BGP
3565 && ri->sub_type == BGP_ROUTE_STATIC)
3566 break;
3567
3568 /* Withdraw static BGP route from routing table. */
3569 if (ri)
3570 {
3571 bgp_aggregate_decrement (bgp, p, ri, afi, safi);
718e3744 3572 bgp_info_delete (rn, ri);
1a392d46 3573 bgp_process (bgp, rn, afi, safi);
718e3744 3574 }
3575
3576 /* Unlock bgp_node_lookup. */
3577 bgp_unlock_node (rn);
3578}
3579
fee0f4c6 3580void
3581bgp_check_local_routes_rsclient (struct peer *rsclient, afi_t afi, safi_t safi)
3582{
3583 struct bgp_static *bgp_static;
3584 struct bgp *bgp;
3585 struct bgp_node *rn;
3586 struct prefix *p;
3587
3588 bgp = rsclient->bgp;
3589
3590 for (rn = bgp_table_top (bgp->route[afi][safi]); rn; rn = bgp_route_next (rn))
3591 if ((bgp_static = rn->info) != NULL)
3592 {
3593 p = &rn->p;
3594
3595 bgp_static_update_rsclient (rsclient, p, bgp_static,
3596 afi, safi);
3597 }
3598}
3599
94f2b392 3600static void
4c9641ba
ML
3601bgp_static_withdraw_vpnv4 (struct bgp *bgp, struct prefix *p, afi_t afi,
3602 safi_t safi, struct prefix_rd *prd, u_char *tag)
718e3744 3603{
3604 struct bgp_node *rn;
3605 struct bgp_info *ri;
3606
fee0f4c6 3607 rn = bgp_afi_node_get (bgp->rib[afi][safi], afi, safi, p, prd);
718e3744 3608
3609 /* Check selected route and self inserted route. */
3610 for (ri = rn->info; ri; ri = ri->next)
3611 if (ri->peer == bgp->peer_self
3612 && ri->type == ZEBRA_ROUTE_BGP
3613 && ri->sub_type == BGP_ROUTE_STATIC)
3614 break;
3615
3616 /* Withdraw static BGP route from routing table. */
3617 if (ri)
3618 {
3619 bgp_aggregate_decrement (bgp, p, ri, afi, safi);
718e3744 3620 bgp_info_delete (rn, ri);
1a392d46 3621 bgp_process (bgp, rn, afi, safi);
718e3744 3622 }
3623
3624 /* Unlock bgp_node_lookup. */
3625 bgp_unlock_node (rn);
3626}
3627
41367172
PJ
3628static void
3629bgp_pathlimit_update_parents (struct bgp *bgp, struct bgp_node *rn,
3630 int ttl_edge)
3631{
3632 struct bgp_node *parent = rn;
3633 struct bgp_static *sp;
3634
3635 /* Existing static changed TTL, search parents and adjust their atomic */
3636 while ((parent = parent->parent))
3637 if ((sp = parent->info))
3638 {
3639 int sp_level = (sp->atomic ? 1 : 0);
3640 ttl_edge ? sp->atomic++ : sp->atomic--;
3641
3642 /* did we change state of parent whether atomic is set or not? */
3643 if (sp_level != (sp->atomic ? 1 : 0))
3644 {
3645 bgp_static_update (bgp, &parent->p, sp,
3646 rn->table->afi, rn->table->safi);
3647 }
3648 }
3649}
3650
718e3744 3651/* Configure static BGP network. When user don't run zebra, static
3652 route should be installed as valid. */
94f2b392 3653static int
fd79ac91 3654bgp_static_set (struct vty *vty, struct bgp *bgp, const char *ip_str,
4c9641ba 3655 afi_t afi, safi_t safi, const char *rmap, int backdoor,
41367172 3656 u_char ttl)
718e3744 3657{
3658 int ret;
3659 struct prefix p;
3660 struct bgp_static *bgp_static;
3661 struct bgp_node *rn;
41367172
PJ
3662 u_char need_update = 0;
3663 u_char ttl_change = 0;
3664 u_char ttl_edge = (ttl ? 1 : 0);
3665 u_char new = 0;
718e3744 3666
3667 /* Convert IP prefix string to struct prefix. */
3668 ret = str2prefix (ip_str, &p);
3669 if (! ret)
3670 {
3671 vty_out (vty, "%% Malformed prefix%s", VTY_NEWLINE);
3672 return CMD_WARNING;
3673 }
3674#ifdef HAVE_IPV6
3675 if (afi == AFI_IP6 && IN6_IS_ADDR_LINKLOCAL (&p.u.prefix6))
3676 {
3677 vty_out (vty, "%% Malformed prefix (link-local address)%s",
3678 VTY_NEWLINE);
3679 return CMD_WARNING;
3680 }
3681#endif /* HAVE_IPV6 */
3682
3683 apply_mask (&p);
3684
3685 /* Set BGP static route configuration. */
3686 rn = bgp_node_get (bgp->route[afi][safi], &p);
3687
3688 if (rn->info)
3689 {
3690 /* Configuration change. */
3691 bgp_static = rn->info;
3692
3693 /* Check previous routes are installed into BGP. */
41367172
PJ
3694 if (bgp_static->valid)
3695 {
3696 if (bgp_static->backdoor != backdoor
3697 || bgp_static->ttl != ttl)
3698 need_update = 1;
3699 }
3700
3701 /* need to catch TTL set/unset transitions for handling of
3702 * ATOMIC_AGGREGATE
3703 */
3704 if ((bgp_static->ttl ? 1 : 0) != ttl_edge)
3705 ttl_change = 1;
3706
718e3744 3707 bgp_static->backdoor = backdoor;
41367172
PJ
3708 bgp_static->ttl = ttl;
3709
718e3744 3710 if (rmap)
3711 {
3712 if (bgp_static->rmap.name)
3713 free (bgp_static->rmap.name);
3714 bgp_static->rmap.name = strdup (rmap);
3715 bgp_static->rmap.map = route_map_lookup_by_name (rmap);
3716 }
3717 else
3718 {
3719 if (bgp_static->rmap.name)
3720 free (bgp_static->rmap.name);
3721 bgp_static->rmap.name = NULL;
3722 bgp_static->rmap.map = NULL;
3723 bgp_static->valid = 0;
3724 }
3725 bgp_unlock_node (rn);
3726 }
3727 else
3728 {
3729 /* New configuration. */
3730 bgp_static = bgp_static_new ();
3731 bgp_static->backdoor = backdoor;
3732 bgp_static->valid = 0;
3733 bgp_static->igpmetric = 0;
3734 bgp_static->igpnexthop.s_addr = 0;
41367172
PJ
3735 bgp_static->ttl = ttl;
3736 ttl_change = ttl_edge;
3737 new = 1;
3738
718e3744 3739 if (rmap)
3740 {
3741 if (bgp_static->rmap.name)
3742 free (bgp_static->rmap.name);
3743 bgp_static->rmap.name = strdup (rmap);
3744 bgp_static->rmap.map = route_map_lookup_by_name (rmap);
3745 }
3746 rn->info = bgp_static;
3747 }
3748
41367172
PJ
3749 /* ".. sites that choose to advertise the
3750 * AS_PATHLIMIT path attribute SHOULD advertise the ATOMIC_AGGREGATE on
3751 * all less specific covering prefixes as well as the more specific
3752 * prefixes."
3753 *
3754 * So:
3755 * Prefix that has just had pathlimit set/unset:
3756 * - Must bump ATOMIC refcount on all parents.
3757 *
3758 * To catch less specific prefixes:
3759 * - Must search children for ones with TTL, bump atomic refcount
3760 * (we dont care if we're deleting a less specific prefix..)
3761 */
3762 if (ttl_change)
3763 {
3764 /* Existing static changed TTL, search parents and adjust their atomic */
3765 bgp_pathlimit_update_parents (bgp, rn, ttl_edge);
3766 }
3767
3768 if (new)
3769 {
3770 struct bgp_node *child;
3771 struct bgp_static *sc;
3772
3773 /* New static, search children and bump this statics atomic.. */
3774 child = bgp_lock_node (rn); /* route_next_until unlocks it.. */
3775 while ((child = bgp_route_next_until (child, rn)))
3776 {
3777 if ((sc = child->info) && sc->ttl)
3778 bgp_static->atomic++;
3779 }
3780 }
3781
718e3744 3782 /* If BGP scan is not enabled, we should install this route here. */
3783 if (! bgp_flag_check (bgp, BGP_FLAG_IMPORT_CHECK))
3784 {
3785 bgp_static->valid = 1;
3786
3787 if (need_update)
3788 bgp_static_withdraw (bgp, &p, afi, safi);
3789
3790 if (! bgp_static->backdoor)
3791 bgp_static_update (bgp, &p, bgp_static, afi, safi);
3792 }
3793
3794 return CMD_SUCCESS;
3795}
3796
3797/* Configure static BGP network. */
94f2b392 3798static int
fd79ac91 3799bgp_static_unset (struct vty *vty, struct bgp *bgp, const char *ip_str,
4c9641ba 3800 afi_t afi, safi_t safi)
718e3744 3801{
3802 int ret;
3803 struct prefix p;
3804 struct bgp_static *bgp_static;
3805 struct bgp_node *rn;
3806
3807 /* Convert IP prefix string to struct prefix. */
3808 ret = str2prefix (ip_str, &p);
3809 if (! ret)
3810 {
3811 vty_out (vty, "%% Malformed prefix%s", VTY_NEWLINE);
3812 return CMD_WARNING;
3813 }
3814#ifdef HAVE_IPV6
3815 if (afi == AFI_IP6 && IN6_IS_ADDR_LINKLOCAL (&p.u.prefix6))
3816 {
3817 vty_out (vty, "%% Malformed prefix (link-local address)%s",
3818 VTY_NEWLINE);
3819 return CMD_WARNING;
3820 }
3821#endif /* HAVE_IPV6 */
3822
3823 apply_mask (&p);
3824
3825 rn = bgp_node_lookup (bgp->route[afi][safi], &p);
3826 if (! rn)
3827 {
3828 vty_out (vty, "%% Can't find specified static route configuration.%s",
3829 VTY_NEWLINE);
3830 return CMD_WARNING;
3831 }
3832
3833 bgp_static = rn->info;
41367172
PJ
3834
3835 /* decrement atomic in parents, see bgp_static_set */
3836 bgp_pathlimit_update_parents (bgp, rn, 0);
3837
718e3744 3838 /* Update BGP RIB. */
3839 if (! bgp_static->backdoor)
3840 bgp_static_withdraw (bgp, &p, afi, safi);
3841
3842 /* Clear configuration. */
3843 bgp_static_free (bgp_static);
3844 rn->info = NULL;
3845 bgp_unlock_node (rn);
3846 bgp_unlock_node (rn);
3847
3848 return CMD_SUCCESS;
3849}
3850
3851/* Called from bgp_delete(). Delete all static routes from the BGP
3852 instance. */
3853void
3854bgp_static_delete (struct bgp *bgp)
3855{
3856 afi_t afi;
3857 safi_t safi;
3858 struct bgp_node *rn;
3859 struct bgp_node *rm;
3860 struct bgp_table *table;
3861 struct bgp_static *bgp_static;
3862
3863 for (afi = AFI_IP; afi < AFI_MAX; afi++)
3864 for (safi = SAFI_UNICAST; safi < SAFI_MAX; safi++)
3865 for (rn = bgp_table_top (bgp->route[afi][safi]); rn; rn = bgp_route_next (rn))
3866 if (rn->info != NULL)
3867 {
3868 if (safi == SAFI_MPLS_VPN)
3869 {
3870 table = rn->info;
3871
3872 for (rm = bgp_table_top (table); rm; rm = bgp_route_next (rm))
3873 {
3874 bgp_static = rn->info;
3875 bgp_static_withdraw_vpnv4 (bgp, &rm->p,
3876 AFI_IP, SAFI_MPLS_VPN,
3877 (struct prefix_rd *)&rn->p,
3878 bgp_static->tag);
3879 bgp_static_free (bgp_static);
3880 rn->info = NULL;
3881 bgp_unlock_node (rn);
3882 }
3883 }
3884 else
3885 {
3886 bgp_static = rn->info;
3887 bgp_static_withdraw (bgp, &rn->p, afi, safi);
3888 bgp_static_free (bgp_static);
3889 rn->info = NULL;
3890 bgp_unlock_node (rn);
3891 }
3892 }
3893}
3894
3895int
fd79ac91 3896bgp_static_set_vpnv4 (struct vty *vty, const char *ip_str, const char *rd_str,
3897 const char *tag_str)
718e3744 3898{
3899 int ret;
3900 struct prefix p;
3901 struct prefix_rd prd;
3902 struct bgp *bgp;
3903 struct bgp_node *prn;
3904 struct bgp_node *rn;
3905 struct bgp_table *table;
3906 struct bgp_static *bgp_static;
3907 u_char tag[3];
3908
3909 bgp = vty->index;
3910
3911 ret = str2prefix (ip_str, &p);
3912 if (! ret)
3913 {
3914 vty_out (vty, "%% Malformed prefix%s", VTY_NEWLINE);
3915 return CMD_WARNING;
3916 }
3917 apply_mask (&p);
3918
3919 ret = str2prefix_rd (rd_str, &prd);
3920 if (! ret)
3921 {
3922 vty_out (vty, "%% Malformed rd%s", VTY_NEWLINE);
3923 return CMD_WARNING;
3924 }
3925
3926 ret = str2tag (tag_str, tag);
3927 if (! ret)
3928 {
3929 vty_out (vty, "%% Malformed tag%s", VTY_NEWLINE);
3930 return CMD_WARNING;
3931 }
3932
3933 prn = bgp_node_get (bgp->route[AFI_IP][SAFI_MPLS_VPN],
3934 (struct prefix *)&prd);
3935 if (prn->info == NULL)
64e580a7 3936 prn->info = bgp_table_init (AFI_IP, SAFI_MPLS_VPN);
718e3744 3937 else
3938 bgp_unlock_node (prn);
3939 table = prn->info;
3940
3941 rn = bgp_node_get (table, &p);
3942
3943 if (rn->info)
3944 {
3945 vty_out (vty, "%% Same network configuration exists%s", VTY_NEWLINE);
3946 bgp_unlock_node (rn);
3947 }
3948 else
3949 {
3950 /* New configuration. */
3951 bgp_static = bgp_static_new ();
3952 bgp_static->valid = 1;
3953 memcpy (bgp_static->tag, tag, 3);
3954 rn->info = bgp_static;
3955
3956 bgp_static_update_vpnv4 (bgp, &p, AFI_IP, SAFI_MPLS_VPN, &prd, tag);
3957 }
3958
3959 return CMD_SUCCESS;
3960}
3961
3962/* Configure static BGP network. */
3963int
fd79ac91 3964bgp_static_unset_vpnv4 (struct vty *vty, const char *ip_str,
3965 const char *rd_str, const char *tag_str)
718e3744 3966{
3967 int ret;
3968 struct bgp *bgp;
3969 struct prefix p;
3970 struct prefix_rd prd;
3971 struct bgp_node *prn;
3972 struct bgp_node *rn;
3973 struct bgp_table *table;
3974 struct bgp_static *bgp_static;
3975 u_char tag[3];
3976
3977 bgp = vty->index;
3978
3979 /* Convert IP prefix string to struct prefix. */
3980 ret = str2prefix (ip_str, &p);
3981 if (! ret)
3982 {
3983 vty_out (vty, "%% Malformed prefix%s", VTY_NEWLINE);
3984 return CMD_WARNING;
3985 }
3986 apply_mask (&p);
3987
3988 ret = str2prefix_rd (rd_str, &prd);
3989 if (! ret)
3990 {
3991 vty_out (vty, "%% Malformed rd%s", VTY_NEWLINE);
3992 return CMD_WARNING;
3993 }
3994
3995 ret = str2tag (tag_str, tag);
3996 if (! ret)
3997 {
3998 vty_out (vty, "%% Malformed tag%s", VTY_NEWLINE);
3999 return CMD_WARNING;
4000 }
4001
4002 prn = bgp_node_get (bgp->route[AFI_IP][SAFI_MPLS_VPN],
4003 (struct prefix *)&prd);
4004 if (prn->info == NULL)
64e580a7 4005 prn->info = bgp_table_init (AFI_IP, SAFI_MPLS_VPN);
718e3744 4006 else
4007 bgp_unlock_node (prn);
4008 table = prn->info;
4009
4010 rn = bgp_node_lookup (table, &p);
4011
4012 if (rn)
4013 {
4014 bgp_static_withdraw_vpnv4 (bgp, &p, AFI_IP, SAFI_MPLS_VPN, &prd, tag);
4015
4016 bgp_static = rn->info;
4017 bgp_static_free (bgp_static);
4018 rn->info = NULL;
4019 bgp_unlock_node (rn);
4020 bgp_unlock_node (rn);
4021 }
4022 else
4023 vty_out (vty, "%% Can't find the route%s", VTY_NEWLINE);
4024
4025 return CMD_SUCCESS;
4026}
4027\f
4028DEFUN (bgp_network,
4029 bgp_network_cmd,
4030 "network A.B.C.D/M",
4031 "Specify a network to announce via BGP\n"
4032 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n")
4033{
41367172
PJ
4034 u_char ttl = 0;
4035
4036 if (argc == 2)
4037 VTY_GET_INTEGER_RANGE ("Pathlimit TTL", ttl, argv[1], 1, 255);
4038
718e3744 4039 return bgp_static_set (vty, vty->index, argv[0],
41367172 4040 AFI_IP, bgp_node_safi (vty), NULL, 0, ttl);
718e3744 4041}
4042
41367172
PJ
4043ALIAS (bgp_network,
4044 bgp_network_ttl_cmd,
4045 "network A.B.C.D/M pathlimit <0-255>",
4046 "Specify a network to announce via BGP\n"
4047 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n"
4048 "AS-Path hopcount limit attribute\n"
4049 "AS-Pathlimit TTL, in number of AS-Path hops\n")
4050
718e3744 4051DEFUN (bgp_network_route_map,
4052 bgp_network_route_map_cmd,
4053 "network A.B.C.D/M route-map WORD",
4054 "Specify a network to announce via BGP\n"
4055 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n"
4056 "Route-map to modify the attributes\n"
4057 "Name of the route map\n")
4058{
4059 return bgp_static_set (vty, vty->index, argv[0],
41367172 4060 AFI_IP, bgp_node_safi (vty), argv[1], 0, 0);
718e3744 4061}
4062
4063DEFUN (bgp_network_backdoor,
4064 bgp_network_backdoor_cmd,
4065 "network A.B.C.D/M backdoor",
4066 "Specify a network to announce via BGP\n"
4067 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n"
4068 "Specify a BGP backdoor route\n")
4069{
41367172
PJ
4070 u_char ttl = 0;
4071
4072 if (argc == 2)
4073 VTY_GET_INTEGER_RANGE ("Pathlimit TTL", ttl, argv[1], 1, 255);
4074
4075 return bgp_static_set (vty, vty->index, argv[0], AFI_IP, SAFI_UNICAST,
4076 NULL, 1, ttl);
718e3744 4077}
4078
41367172
PJ
4079ALIAS (bgp_network_backdoor,
4080 bgp_network_backdoor_ttl_cmd,
4081 "network A.B.C.D/M backdoor pathlimit <0-255>",
4082 "Specify a network to announce via BGP\n"
4083 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n"
4084 "Specify a BGP backdoor route\n"
4085 "AS-Path hopcount limit attribute\n"
4086 "AS-Pathlimit TTL, in number of AS-Path hops\n")
4087
718e3744 4088DEFUN (bgp_network_mask,
4089 bgp_network_mask_cmd,
4090 "network A.B.C.D mask A.B.C.D",
4091 "Specify a network to announce via BGP\n"
4092 "Network number\n"
4093 "Network mask\n"
4094 "Network mask\n")
4095{
4096 int ret;
4097 char prefix_str[BUFSIZ];
41367172
PJ
4098 u_char ttl = 0;
4099
4100 if (argc == 3)
4101 VTY_GET_INTEGER_RANGE ("Pathlimit TTL", ttl, argv[2], 1, 255);
4102
718e3744 4103 ret = netmask_str2prefix_str (argv[0], argv[1], prefix_str);
4104 if (! ret)
4105 {
4106 vty_out (vty, "%% Inconsistent address and mask%s", VTY_NEWLINE);
4107 return CMD_WARNING;
4108 }
4109
4110 return bgp_static_set (vty, vty->index, prefix_str,
41367172 4111 AFI_IP, bgp_node_safi (vty), NULL, 0, ttl);
718e3744 4112}
4113
41367172
PJ
4114ALIAS (bgp_network_mask,
4115 bgp_network_mask_ttl_cmd,
4116 "network A.B.C.D mask A.B.C.D pathlimit <0-255>",
4117 "Specify a network to announce via BGP\n"
4118 "Network number\n"
4119 "Network mask\n"
4120 "Network mask\n"
4121 "AS-Path hopcount limit attribute\n"
4122 "AS-Pathlimit TTL, in number of AS-Path hops\n")
4123
718e3744 4124DEFUN (bgp_network_mask_route_map,
4125 bgp_network_mask_route_map_cmd,
4126 "network A.B.C.D mask A.B.C.D route-map WORD",
4127 "Specify a network to announce via BGP\n"
4128 "Network number\n"
4129 "Network mask\n"
4130 "Network mask\n"
4131 "Route-map to modify the attributes\n"
4132 "Name of the route map\n")
4133{
4134 int ret;
4135 char prefix_str[BUFSIZ];
41367172 4136
718e3744 4137 ret = netmask_str2prefix_str (argv[0], argv[1], prefix_str);
4138 if (! ret)
4139 {
4140 vty_out (vty, "%% Inconsistent address and mask%s", VTY_NEWLINE);
4141 return CMD_WARNING;
4142 }
4143
4144 return bgp_static_set (vty, vty->index, prefix_str,
41367172 4145 AFI_IP, bgp_node_safi (vty), argv[2], 0, 0);
718e3744 4146}
4147
4148DEFUN (bgp_network_mask_backdoor,
4149 bgp_network_mask_backdoor_cmd,
4150 "network A.B.C.D mask A.B.C.D backdoor",
4151 "Specify a network to announce via BGP\n"
4152 "Network number\n"
4153 "Network mask\n"
4154 "Network mask\n"
4155 "Specify a BGP backdoor route\n")
4156{
4157 int ret;
4158 char prefix_str[BUFSIZ];
41367172
PJ
4159 u_char ttl = 0;
4160
4161 if (argc == 3)
4162 VTY_GET_INTEGER_RANGE ("Pathlimit TTL", ttl, argv[2], 1, 255);
718e3744 4163
4164 ret = netmask_str2prefix_str (argv[0], argv[1], prefix_str);
4165 if (! ret)
4166 {
4167 vty_out (vty, "%% Inconsistent address and mask%s", VTY_NEWLINE);
4168 return CMD_WARNING;
4169 }
4170
41367172
PJ
4171 return bgp_static_set (vty, vty->index, prefix_str, AFI_IP, SAFI_UNICAST,
4172 NULL, 1, ttl);
718e3744 4173}
4174
41367172
PJ
4175ALIAS (bgp_network_mask_backdoor,
4176 bgp_network_mask_backdoor_ttl_cmd,
4177 "network A.B.C.D mask A.B.C.D backdoor pathlimit <0-255>",
4178 "Specify a network to announce via BGP\n"
4179 "Network number\n"
4180 "Network mask\n"
4181 "Network mask\n"
4182 "Specify a BGP backdoor route\n"
4183 "AS-Path hopcount limit attribute\n"
4184 "AS-Pathlimit TTL, in number of AS-Path hops\n")
4185
718e3744 4186DEFUN (bgp_network_mask_natural,
4187 bgp_network_mask_natural_cmd,
4188 "network A.B.C.D",
4189 "Specify a network to announce via BGP\n"
4190 "Network number\n")
4191{
4192 int ret;
4193 char prefix_str[BUFSIZ];
41367172
PJ
4194 u_char ttl = 0;
4195
4196 if (argc == 2)
4197 VTY_GET_INTEGER_RANGE ("Pathlimit TTL", ttl, argv[1], 1, 255);
718e3744 4198
4199 ret = netmask_str2prefix_str (argv[0], NULL, prefix_str);
4200 if (! ret)
4201 {
4202 vty_out (vty, "%% Inconsistent address and mask%s", VTY_NEWLINE);
4203 return CMD_WARNING;
4204 }
4205
4206 return bgp_static_set (vty, vty->index, prefix_str,
41367172 4207 AFI_IP, bgp_node_safi (vty), NULL, 0, ttl);
718e3744 4208}
4209
41367172
PJ
4210ALIAS (bgp_network_mask_natural,
4211 bgp_network_mask_natural_ttl_cmd,
4212 "network A.B.C.D pathlimit <0-255>",
4213 "Specify a network to announce via BGP\n"
4214 "Network number\n"
4215 "AS-Path hopcount limit attribute\n"
4216 "AS-Pathlimit TTL, in number of AS-Path hops\n")
4217
718e3744 4218DEFUN (bgp_network_mask_natural_route_map,
4219 bgp_network_mask_natural_route_map_cmd,
4220 "network A.B.C.D route-map WORD",
4221 "Specify a network to announce via BGP\n"
4222 "Network number\n"
4223 "Route-map to modify the attributes\n"
4224 "Name of the route map\n")
4225{
4226 int ret;
4227 char prefix_str[BUFSIZ];
4228
4229 ret = netmask_str2prefix_str (argv[0], NULL, prefix_str);
4230 if (! ret)
4231 {
4232 vty_out (vty, "%% Inconsistent address and mask%s", VTY_NEWLINE);
4233 return CMD_WARNING;
4234 }
4235
4236 return bgp_static_set (vty, vty->index, prefix_str,
41367172 4237 AFI_IP, bgp_node_safi (vty), argv[1], 0, 0);
718e3744 4238}
4239
4240DEFUN (bgp_network_mask_natural_backdoor,
4241 bgp_network_mask_natural_backdoor_cmd,
4242 "network A.B.C.D backdoor",
4243 "Specify a network to announce via BGP\n"
4244 "Network number\n"
4245 "Specify a BGP backdoor route\n")
4246{
4247 int ret;
4248 char prefix_str[BUFSIZ];
41367172
PJ
4249 u_char ttl = 0;
4250
4251 if (argc == 2)
4252 VTY_GET_INTEGER_RANGE ("Pathlimit TTL", ttl, argv[1], 1, 255);
718e3744 4253
4254 ret = netmask_str2prefix_str (argv[0], NULL, prefix_str);
4255 if (! ret)
4256 {
4257 vty_out (vty, "%% Inconsistent address and mask%s", VTY_NEWLINE);
4258 return CMD_WARNING;
4259 }
4260
41367172
PJ
4261 return bgp_static_set (vty, vty->index, prefix_str, AFI_IP, SAFI_UNICAST,
4262 NULL, 1, ttl);
718e3744 4263}
4264
41367172
PJ
4265ALIAS (bgp_network_mask_natural_backdoor,
4266 bgp_network_mask_natural_backdoor_ttl_cmd,
4267 "network A.B.C.D backdoor pathlimit (1-255>",
4268 "Specify a network to announce via BGP\n"
4269 "Network number\n"
4270 "Specify a BGP backdoor route\n"
4271 "AS-Path hopcount limit attribute\n"
4272 "AS-Pathlimit TTL, in number of AS-Path hops\n")
4273
718e3744 4274DEFUN (no_bgp_network,
4275 no_bgp_network_cmd,
4276 "no network A.B.C.D/M",
4277 NO_STR
4278 "Specify a network to announce via BGP\n"
4279 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n")
4280{
4281 return bgp_static_unset (vty, vty->index, argv[0], AFI_IP,
4282 bgp_node_safi (vty));
4283}
4284
41367172
PJ
4285ALIAS (no_bgp_network,
4286 no_bgp_network_ttl_cmd,
4287 "no network A.B.C.D/M pathlimit <0-255>",
4288 NO_STR
4289 "Specify a network to announce via BGP\n"
4290 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n"
4291 "AS-Path hopcount limit attribute\n"
4292 "AS-Pathlimit TTL, in number of AS-Path hops\n")
4293
718e3744 4294ALIAS (no_bgp_network,
4295 no_bgp_network_route_map_cmd,
4296 "no network A.B.C.D/M route-map WORD",
4297 NO_STR
4298 "Specify a network to announce via BGP\n"
4299 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n"
4300 "Route-map to modify the attributes\n"
4301 "Name of the route map\n")
4302
4303ALIAS (no_bgp_network,
4304 no_bgp_network_backdoor_cmd,
4305 "no network A.B.C.D/M backdoor",
4306 NO_STR
4307 "Specify a network to announce via BGP\n"
4308 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n"
4309 "Specify a BGP backdoor route\n")
4310
41367172
PJ
4311ALIAS (no_bgp_network,
4312 no_bgp_network_backdoor_ttl_cmd,
4313 "no network A.B.C.D/M backdoor pathlimit <0-255>",
4314 NO_STR
4315 "Specify a network to announce via BGP\n"
4316 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n"
4317 "Specify a BGP backdoor route\n"
4318 "AS-Path hopcount limit attribute\n"
4319 "AS-Pathlimit TTL, in number of AS-Path hops\n")
4320
718e3744 4321DEFUN (no_bgp_network_mask,
4322 no_bgp_network_mask_cmd,
4323 "no network A.B.C.D mask A.B.C.D",
4324 NO_STR
4325 "Specify a network to announce via BGP\n"
4326 "Network number\n"
4327 "Network mask\n"
4328 "Network mask\n")
4329{
4330 int ret;
4331 char prefix_str[BUFSIZ];
4332
4333 ret = netmask_str2prefix_str (argv[0], argv[1], prefix_str);
4334 if (! ret)
4335 {
4336 vty_out (vty, "%% Inconsistent address and mask%s", VTY_NEWLINE);
4337 return CMD_WARNING;
4338 }
4339
4340 return bgp_static_unset (vty, vty->index, prefix_str, AFI_IP,
4341 bgp_node_safi (vty));
4342}
4343
41367172
PJ
4344ALIAS (no_bgp_network,
4345 no_bgp_network_mask_ttl_cmd,
4346 "no network A.B.C.D mask A.B.C.D pathlimit <0-255>",
4347 NO_STR
4348 "Specify a network to announce via BGP\n"
4349 "Network number\n"
4350 "Network mask\n"
4351 "Network mask\n"
4352 "AS-Path hopcount limit attribute\n"
4353 "AS-Pathlimit TTL, in number of AS-Path hops\n")
4354
718e3744 4355ALIAS (no_bgp_network_mask,
4356 no_bgp_network_mask_route_map_cmd,
4357 "no network A.B.C.D mask A.B.C.D route-map WORD",
4358 NO_STR
4359 "Specify a network to announce via BGP\n"
4360 "Network number\n"
4361 "Network mask\n"
4362 "Network mask\n"
4363 "Route-map to modify the attributes\n"
4364 "Name of the route map\n")
4365
4366ALIAS (no_bgp_network_mask,
4367 no_bgp_network_mask_backdoor_cmd,
4368 "no network A.B.C.D mask A.B.C.D backdoor",
4369 NO_STR
4370 "Specify a network to announce via BGP\n"
4371 "Network number\n"
4372 "Network mask\n"
4373 "Network mask\n"
4374 "Specify a BGP backdoor route\n")
4375
41367172
PJ
4376ALIAS (no_bgp_network_mask,
4377 no_bgp_network_mask_backdoor_ttl_cmd,
4378 "no network A.B.C.D mask A.B.C.D backdoor pathlimit <0-255>",
4379 NO_STR
4380 "Specify a network to announce via BGP\n"
4381 "Network number\n"
4382 "Network mask\n"
4383 "Network mask\n"
4384 "Specify a BGP backdoor route\n"
4385 "AS-Path hopcount limit attribute\n"
4386 "AS-Pathlimit TTL, in number of AS-Path hops\n")
4387
718e3744 4388DEFUN (no_bgp_network_mask_natural,
4389 no_bgp_network_mask_natural_cmd,
4390 "no network A.B.C.D",
4391 NO_STR
4392 "Specify a network to announce via BGP\n"
4393 "Network number\n")
4394{
4395 int ret;
4396 char prefix_str[BUFSIZ];
4397
4398 ret = netmask_str2prefix_str (argv[0], NULL, prefix_str);
4399 if (! ret)
4400 {
4401 vty_out (vty, "%% Inconsistent address and mask%s", VTY_NEWLINE);
4402 return CMD_WARNING;
4403 }
4404
4405 return bgp_static_unset (vty, vty->index, prefix_str, AFI_IP,
4406 bgp_node_safi (vty));
4407}
4408
4409ALIAS (no_bgp_network_mask_natural,
4410 no_bgp_network_mask_natural_route_map_cmd,
4411 "no network A.B.C.D route-map WORD",
4412 NO_STR
4413 "Specify a network to announce via BGP\n"
4414 "Network number\n"
4415 "Route-map to modify the attributes\n"
4416 "Name of the route map\n")
4417
4418ALIAS (no_bgp_network_mask_natural,
4419 no_bgp_network_mask_natural_backdoor_cmd,
4420 "no network A.B.C.D backdoor",
4421 NO_STR
4422 "Specify a network to announce via BGP\n"
4423 "Network number\n"
4424 "Specify a BGP backdoor route\n")
4425
41367172
PJ
4426ALIAS (no_bgp_network_mask_natural,
4427 no_bgp_network_mask_natural_ttl_cmd,
4428 "no network A.B.C.D pathlimit <0-255>",
4429 NO_STR
4430 "Specify a network to announce via BGP\n"
4431 "Network number\n"
4432 "AS-Path hopcount limit attribute\n"
4433 "AS-Pathlimit TTL, in number of AS-Path hops\n")
4434
4435ALIAS (no_bgp_network_mask_natural,
4436 no_bgp_network_mask_natural_backdoor_ttl_cmd,
4437 "no network A.B.C.D backdoor pathlimit <0-255>",
4438 NO_STR
4439 "Specify a network to announce via BGP\n"
4440 "Network number\n"
4441 "Specify a BGP backdoor route\n"
4442 "AS-Path hopcount limit attribute\n"
4443 "AS-Pathlimit TTL, in number of AS-Path hops\n")
4444
718e3744 4445#ifdef HAVE_IPV6
4446DEFUN (ipv6_bgp_network,
4447 ipv6_bgp_network_cmd,
4448 "network X:X::X:X/M",
4449 "Specify a network to announce via BGP\n"
4450 "IPv6 prefix <network>/<length>\n")
4451{
41367172
PJ
4452 u_char ttl = 0;
4453
4454 if (argc == 2)
4455 VTY_GET_INTEGER_RANGE ("Pathlimit TTL", ttl, argv[1], 1, 255);
4456
4457 return bgp_static_set (vty, vty->index, argv[0], AFI_IP6, SAFI_UNICAST,
4458 NULL, 0, ttl);
718e3744 4459}
4460
41367172
PJ
4461ALIAS (ipv6_bgp_network,
4462 ipv6_bgp_network_ttl_cmd,
4463 "network X:X::X:X/M pathlimit <0-255>",
4464 "Specify a network to announce via BGP\n"
4465 "IPv6 prefix <network>/<length>\n"
4466 "AS-Path hopcount limit attribute\n"
4467 "AS-Pathlimit TTL, in number of AS-Path hops\n")
4468
718e3744 4469DEFUN (ipv6_bgp_network_route_map,
4470 ipv6_bgp_network_route_map_cmd,
4471 "network X:X::X:X/M route-map WORD",
4472 "Specify a network to announce via BGP\n"
4473 "IPv6 prefix <network>/<length>\n"
4474 "Route-map to modify the attributes\n"
4475 "Name of the route map\n")
4476{
4477 return bgp_static_set (vty, vty->index, argv[0], AFI_IP6,
41367172 4478 bgp_node_safi (vty), argv[1], 0, 0);
718e3744 4479}
4480
4481DEFUN (no_ipv6_bgp_network,
4482 no_ipv6_bgp_network_cmd,
4483 "no network X:X::X:X/M",
4484 NO_STR
4485 "Specify a network to announce via BGP\n"
4486 "IPv6 prefix <network>/<length>\n")
4487{
4488 return bgp_static_unset (vty, vty->index, argv[0], AFI_IP6, SAFI_UNICAST);
4489}
4490
4491ALIAS (no_ipv6_bgp_network,
4492 no_ipv6_bgp_network_route_map_cmd,
4493 "no network X:X::X:X/M route-map WORD",
4494 NO_STR
4495 "Specify a network to announce via BGP\n"
4496 "IPv6 prefix <network>/<length>\n"
4497 "Route-map to modify the attributes\n"
4498 "Name of the route map\n")
4499
41367172
PJ
4500ALIAS (no_ipv6_bgp_network,
4501 no_ipv6_bgp_network_ttl_cmd,
4502 "no network X:X::X:X/M pathlimit <0-255>",
4503 NO_STR
4504 "Specify a network to announce via BGP\n"
4505 "IPv6 prefix <network>/<length>\n"
4506 "AS-Path hopcount limit attribute\n"
4507 "AS-Pathlimit TTL, in number of AS-Path hops\n")
4508
718e3744 4509ALIAS (ipv6_bgp_network,
4510 old_ipv6_bgp_network_cmd,
4511 "ipv6 bgp network X:X::X:X/M",
4512 IPV6_STR
4513 BGP_STR
4514 "Specify a network to announce via BGP\n"
4515 "IPv6 prefix <network>/<length>, e.g., 3ffe::/16\n")
4516
4517ALIAS (no_ipv6_bgp_network,
4518 old_no_ipv6_bgp_network_cmd,
4519 "no ipv6 bgp network X:X::X:X/M",
4520 NO_STR
4521 IPV6_STR
4522 BGP_STR
4523 "Specify a network to announce via BGP\n"
4524 "IPv6 prefix <network>/<length>, e.g., 3ffe::/16\n")
4525#endif /* HAVE_IPV6 */
4526\f
4527/* Aggreagete address:
4528
4529 advertise-map Set condition to advertise attribute
4530 as-set Generate AS set path information
4531 attribute-map Set attributes of aggregate
4532 route-map Set parameters of aggregate
4533 summary-only Filter more specific routes from updates
4534 suppress-map Conditionally filter more specific routes from updates
4535 <cr>
4536 */
4537struct bgp_aggregate
4538{
4539 /* Summary-only flag. */
4540 u_char summary_only;
4541
4542 /* AS set generation. */
4543 u_char as_set;
4544
4545 /* Route-map for aggregated route. */
4546 struct route_map *map;
4547
4548 /* Suppress-count. */
4549 unsigned long count;
4550
4551 /* SAFI configuration. */
4552 safi_t safi;
4553};
4554
94f2b392 4555static struct bgp_aggregate *
66e5cd87 4556bgp_aggregate_new (void)
718e3744 4557{
393deb9b 4558 return XCALLOC (MTYPE_BGP_AGGREGATE, sizeof (struct bgp_aggregate));
718e3744 4559}
4560
94f2b392 4561static void
718e3744 4562bgp_aggregate_free (struct bgp_aggregate *aggregate)
4563{
4564 XFREE (MTYPE_BGP_AGGREGATE, aggregate);
4565}
4566
94f2b392 4567static void
718e3744 4568bgp_aggregate_route (struct bgp *bgp, struct prefix *p, struct bgp_info *rinew,
4569 afi_t afi, safi_t safi, struct bgp_info *del,
4570 struct bgp_aggregate *aggregate)
4571{
4572 struct bgp_table *table;
4573 struct bgp_node *top;
4574 struct bgp_node *rn;
4575 u_char origin;
4576 struct aspath *aspath = NULL;
4577 struct aspath *asmerge = NULL;
4578 struct community *community = NULL;
4579 struct community *commerge = NULL;
4580 struct in_addr nexthop;
4581 u_int32_t med = 0;
4582 struct bgp_info *ri;
4583 struct bgp_info *new;
4584 int first = 1;
4585 unsigned long match = 0;
4586
4587 /* Record adding route's nexthop and med. */
4588 if (rinew)
4589 {
4590 nexthop = rinew->attr->nexthop;
4591 med = rinew->attr->med;
4592 }
4593
4594 /* ORIGIN attribute: If at least one route among routes that are
4595 aggregated has ORIGIN with the value INCOMPLETE, then the
4596 aggregated route must have the ORIGIN attribute with the value
4597 INCOMPLETE. Otherwise, if at least one route among routes that
4598 are aggregated has ORIGIN with the value EGP, then the aggregated
4599 route must have the origin attribute with the value EGP. In all
4600 other case the value of the ORIGIN attribute of the aggregated
4601 route is INTERNAL. */
4602 origin = BGP_ORIGIN_IGP;
4603
4604 table = bgp->rib[afi][safi];
4605
4606 top = bgp_node_get (table, p);
4607 for (rn = bgp_node_get (table, p); rn; rn = bgp_route_next_until (rn, top))
4608 if (rn->p.prefixlen > p->prefixlen)
4609 {
4610 match = 0;
4611
4612 for (ri = rn->info; ri; ri = ri->next)
4613 {
4614 if (BGP_INFO_HOLDDOWN (ri))
4615 continue;
4616
4617 if (del && ri == del)
4618 continue;
4619
4620 if (! rinew && first)
4621 {
4622 nexthop = ri->attr->nexthop;
4623 med = ri->attr->med;
4624 first = 0;
4625 }
4626
4627#ifdef AGGREGATE_NEXTHOP_CHECK
4628 if (! IPV4_ADDR_SAME (&ri->attr->nexthop, &nexthop)
4629 || ri->attr->med != med)
4630 {
4631 if (aspath)
4632 aspath_free (aspath);
4633 if (community)
4634 community_free (community);
4635 bgp_unlock_node (rn);
4636 bgp_unlock_node (top);
4637 return;
4638 }
4639#endif /* AGGREGATE_NEXTHOP_CHECK */
4640
4641 if (ri->sub_type != BGP_ROUTE_AGGREGATE)
4642 {
4643 if (aggregate->summary_only)
4644 {
fb982c25 4645 (bgp_info_extra_get (ri))->suppress++;
1a392d46 4646 bgp_info_set_flag (rn, ri, BGP_INFO_ATTR_CHANGED);
718e3744 4647 match++;
4648 }
4649
4650 aggregate->count++;
4651
4652 if (aggregate->as_set)
4653 {
4654 if (origin < ri->attr->origin)
4655 origin = ri->attr->origin;
4656
4657 if (aspath)
4658 {
4659 asmerge = aspath_aggregate (aspath, ri->attr->aspath);
4660 aspath_free (aspath);
4661 aspath = asmerge;
4662 }
4663 else
4664 aspath = aspath_dup (ri->attr->aspath);
4665
4666 if (ri->attr->community)
4667 {
4668 if (community)
4669 {
4670 commerge = community_merge (community,
4671 ri->attr->community);
4672 community = community_uniq_sort (commerge);
4673 community_free (commerge);
4674 }
4675 else
4676 community = community_dup (ri->attr->community);
4677 }
4678 }
4679 }
4680 }
4681 if (match)
4682 bgp_process (bgp, rn, afi, safi);
4683 }
4684 bgp_unlock_node (top);
4685
4686 if (rinew)
4687 {
4688 aggregate->count++;
4689
4690 if (aggregate->summary_only)
fb982c25 4691 (bgp_info_extra_get (rinew))->suppress++;
718e3744 4692
4693 if (aggregate->as_set)
4694 {
4695 if (origin < rinew->attr->origin)
4696 origin = rinew->attr->origin;
4697
4698 if (aspath)
4699 {
4700 asmerge = aspath_aggregate (aspath, rinew->attr->aspath);
4701 aspath_free (aspath);
4702 aspath = asmerge;
4703 }
4704 else
4705 aspath = aspath_dup (rinew->attr->aspath);
4706
4707 if (rinew->attr->community)
4708 {
4709 if (community)
4710 {
4711 commerge = community_merge (community,
4712 rinew->attr->community);
4713 community = community_uniq_sort (commerge);
4714 community_free (commerge);
4715 }
4716 else
4717 community = community_dup (rinew->attr->community);
4718 }
4719 }
4720 }
4721
4722 if (aggregate->count > 0)
4723 {
4724 rn = bgp_node_get (table, p);
4725 new = bgp_info_new ();
4726 new->type = ZEBRA_ROUTE_BGP;
4727 new->sub_type = BGP_ROUTE_AGGREGATE;
4728 new->peer = bgp->peer_self;
4729 SET_FLAG (new->flags, BGP_INFO_VALID);
4730 new->attr = bgp_attr_aggregate_intern (bgp, origin, aspath, community, aggregate->as_set);
65957886 4731 new->uptime = bgp_clock ();
718e3744 4732
4733 bgp_info_add (rn, new);
200df115 4734 bgp_unlock_node (rn);
718e3744 4735 bgp_process (bgp, rn, afi, safi);
4736 }
4737 else
4738 {
4739 if (aspath)
4740 aspath_free (aspath);
4741 if (community)
4742 community_free (community);
4743 }
4744}
4745
4746void bgp_aggregate_delete (struct bgp *, struct prefix *, afi_t, safi_t,
4747 struct bgp_aggregate *);
4748
4749void
4750bgp_aggregate_increment (struct bgp *bgp, struct prefix *p,
4751 struct bgp_info *ri, afi_t afi, safi_t safi)
4752{
4753 struct bgp_node *child;
4754 struct bgp_node *rn;
4755 struct bgp_aggregate *aggregate;
4756
4757 /* MPLS-VPN aggregation is not yet supported. */
4758 if (safi == SAFI_MPLS_VPN)
4759 return;
4760
4761 if (p->prefixlen == 0)
4762 return;
4763
4764 if (BGP_INFO_HOLDDOWN (ri))
4765 return;
4766
4767 child = bgp_node_get (bgp->aggregate[afi][safi], p);
4768
4769 /* Aggregate address configuration check. */
4770 for (rn = child; rn; rn = rn->parent)
4771 if ((aggregate = rn->info) != NULL && rn->p.prefixlen < p->prefixlen)
4772 {
4773 bgp_aggregate_delete (bgp, &rn->p, afi, safi, aggregate);
286e1e71 4774 bgp_aggregate_route (bgp, &rn->p, ri, afi, safi, NULL, aggregate);
718e3744 4775 }
4776 bgp_unlock_node (child);
4777}
4778
4779void
4780bgp_aggregate_decrement (struct bgp *bgp, struct prefix *p,
4781 struct bgp_info *del, afi_t afi, safi_t safi)
4782{
4783 struct bgp_node *child;
4784 struct bgp_node *rn;
4785 struct bgp_aggregate *aggregate;
4786
4787 /* MPLS-VPN aggregation is not yet supported. */
4788 if (safi == SAFI_MPLS_VPN)
4789 return;
4790
4791 if (p->prefixlen == 0)
4792 return;
4793
4794 child = bgp_node_get (bgp->aggregate[afi][safi], p);
4795
4796 /* Aggregate address configuration check. */
4797 for (rn = child; rn; rn = rn->parent)
4798 if ((aggregate = rn->info) != NULL && rn->p.prefixlen < p->prefixlen)
4799 {
4800 bgp_aggregate_delete (bgp, &rn->p, afi, safi, aggregate);
286e1e71 4801 bgp_aggregate_route (bgp, &rn->p, NULL, afi, safi, del, aggregate);
718e3744 4802 }
4803 bgp_unlock_node (child);
4804}
4805
94f2b392 4806static void
718e3744 4807bgp_aggregate_add (struct bgp *bgp, struct prefix *p, afi_t afi, safi_t safi,
4808 struct bgp_aggregate *aggregate)
4809{
4810 struct bgp_table *table;
4811 struct bgp_node *top;
4812 struct bgp_node *rn;
4813 struct bgp_info *new;
4814 struct bgp_info *ri;
4815 unsigned long match;
4816 u_char origin = BGP_ORIGIN_IGP;
4817 struct aspath *aspath = NULL;
4818 struct aspath *asmerge = NULL;
4819 struct community *community = NULL;
4820 struct community *commerge = NULL;
4821
4822 table = bgp->rib[afi][safi];
4823
4824 /* Sanity check. */
4825 if (afi == AFI_IP && p->prefixlen == IPV4_MAX_BITLEN)
4826 return;
4827 if (afi == AFI_IP6 && p->prefixlen == IPV6_MAX_BITLEN)
4828 return;
4829
4830 /* If routes exists below this node, generate aggregate routes. */
4831 top = bgp_node_get (table, p);
4832 for (rn = bgp_node_get (table, p); rn; rn = bgp_route_next_until (rn, top))
4833 if (rn->p.prefixlen > p->prefixlen)
4834 {
4835 match = 0;
4836
4837 for (ri = rn->info; ri; ri = ri->next)
4838 {
4839 if (BGP_INFO_HOLDDOWN (ri))
4840 continue;
4841
4842 if (ri->sub_type != BGP_ROUTE_AGGREGATE)
4843 {
4844 /* summary-only aggregate route suppress aggregated
4845 route announcement. */
4846 if (aggregate->summary_only)
4847 {
fb982c25 4848 (bgp_info_extra_get (ri))->suppress++;
1a392d46 4849 bgp_info_set_flag (rn, ri, BGP_INFO_ATTR_CHANGED);
718e3744 4850 match++;
4851 }
4852 /* as-set aggregate route generate origin, as path,
4853 community aggregation. */
4854 if (aggregate->as_set)
4855 {
4856 if (origin < ri->attr->origin)
4857 origin = ri->attr->origin;
4858
4859 if (aspath)
4860 {
4861 asmerge = aspath_aggregate (aspath, ri->attr->aspath);
4862 aspath_free (aspath);
4863 aspath = asmerge;
4864 }
4865 else
4866 aspath = aspath_dup (ri->attr->aspath);
4867
4868 if (ri->attr->community)
4869 {
4870 if (community)
4871 {
4872 commerge = community_merge (community,
4873 ri->attr->community);
4874 community = community_uniq_sort (commerge);
4875 community_free (commerge);
4876 }
4877 else
4878 community = community_dup (ri->attr->community);
4879 }
4880 }
4881 aggregate->count++;
4882 }
4883 }
4884
4885 /* If this node is suppressed, process the change. */
4886 if (match)
4887 bgp_process (bgp, rn, afi, safi);
4888 }
4889 bgp_unlock_node (top);
4890
4891 /* Add aggregate route to BGP table. */
4892 if (aggregate->count)
4893 {
4894 rn = bgp_node_get (table, p);
4895
4896 new = bgp_info_new ();
4897 new->type = ZEBRA_ROUTE_BGP;
4898 new->sub_type = BGP_ROUTE_AGGREGATE;
4899 new->peer = bgp->peer_self;
4900 SET_FLAG (new->flags, BGP_INFO_VALID);
4901 new->attr = bgp_attr_aggregate_intern (bgp, origin, aspath, community, aggregate->as_set);
65957886 4902 new->uptime = bgp_clock ();
718e3744 4903
4904 bgp_info_add (rn, new);
200df115 4905 bgp_unlock_node (rn);
4906
718e3744 4907 /* Process change. */
4908 bgp_process (bgp, rn, afi, safi);
4909 }
4910}
4911
4912void
4913bgp_aggregate_delete (struct bgp *bgp, struct prefix *p, afi_t afi,
4914 safi_t safi, struct bgp_aggregate *aggregate)
4915{
4916 struct bgp_table *table;
4917 struct bgp_node *top;
4918 struct bgp_node *rn;
4919 struct bgp_info *ri;
4920 unsigned long match;
4921
4922 table = bgp->rib[afi][safi];
4923
4924 if (afi == AFI_IP && p->prefixlen == IPV4_MAX_BITLEN)
4925 return;
4926 if (afi == AFI_IP6 && p->prefixlen == IPV6_MAX_BITLEN)
4927 return;
4928
4929 /* If routes exists below this node, generate aggregate routes. */
4930 top = bgp_node_get (table, p);
4931 for (rn = bgp_node_get (table, p); rn; rn = bgp_route_next_until (rn, top))
4932 if (rn->p.prefixlen > p->prefixlen)
4933 {
4934 match = 0;
4935
4936 for (ri = rn->info; ri; ri = ri->next)
4937 {
4938 if (BGP_INFO_HOLDDOWN (ri))
4939 continue;
4940
4941 if (ri->sub_type != BGP_ROUTE_AGGREGATE)
4942 {
fb982c25 4943 if (aggregate->summary_only && ri->extra)
718e3744 4944 {
fb982c25 4945 ri->extra->suppress--;
718e3744 4946
fb982c25 4947 if (ri->extra->suppress == 0)
718e3744 4948 {
1a392d46 4949 bgp_info_set_flag (rn, ri, BGP_INFO_ATTR_CHANGED);
718e3744 4950 match++;
4951 }
4952 }
4953 aggregate->count--;
4954 }
4955 }
4956
fb982c25 4957 /* If this node was suppressed, process the change. */
718e3744 4958 if (match)
4959 bgp_process (bgp, rn, afi, safi);
4960 }
4961 bgp_unlock_node (top);
4962
4963 /* Delete aggregate route from BGP table. */
4964 rn = bgp_node_get (table, p);
4965
4966 for (ri = rn->info; ri; ri = ri->next)
4967 if (ri->peer == bgp->peer_self
4968 && ri->type == ZEBRA_ROUTE_BGP
4969 && ri->sub_type == BGP_ROUTE_AGGREGATE)
4970 break;
4971
4972 /* Withdraw static BGP route from routing table. */
4973 if (ri)
4974 {
718e3744 4975 bgp_info_delete (rn, ri);
1a392d46 4976 bgp_process (bgp, rn, afi, safi);
718e3744 4977 }
4978
4979 /* Unlock bgp_node_lookup. */
4980 bgp_unlock_node (rn);
4981}
4982
4983/* Aggregate route attribute. */
4984#define AGGREGATE_SUMMARY_ONLY 1
4985#define AGGREGATE_AS_SET 1
4986
94f2b392 4987static int
fd79ac91 4988bgp_aggregate_set (struct vty *vty, const char *prefix_str,
4989 afi_t afi, safi_t safi,
718e3744 4990 u_char summary_only, u_char as_set)
4991{
4992 int ret;
4993 struct prefix p;
4994 struct bgp_node *rn;
4995 struct bgp *bgp;
4996 struct bgp_aggregate *aggregate;
4997
4998 /* Convert string to prefix structure. */
4999 ret = str2prefix (prefix_str, &p);
5000 if (!ret)
5001 {
5002 vty_out (vty, "Malformed prefix%s", VTY_NEWLINE);
5003 return CMD_WARNING;
5004 }
5005 apply_mask (&p);
5006
5007 /* Get BGP structure. */
5008 bgp = vty->index;
5009
5010 /* Old configuration check. */
5011 rn = bgp_node_get (bgp->aggregate[afi][safi], &p);
5012
5013 if (rn->info)
5014 {
5015 vty_out (vty, "There is already same aggregate network.%s", VTY_NEWLINE);
5016 bgp_unlock_node (rn);
5017 return CMD_WARNING;
5018 }
5019
5020 /* Make aggregate address structure. */
5021 aggregate = bgp_aggregate_new ();
5022 aggregate->summary_only = summary_only;
5023 aggregate->as_set = as_set;
5024 aggregate->safi = safi;
5025 rn->info = aggregate;
5026
5027 /* Aggregate address insert into BGP routing table. */
5028 if (safi & SAFI_UNICAST)
5029 bgp_aggregate_add (bgp, &p, afi, SAFI_UNICAST, aggregate);
5030 if (safi & SAFI_MULTICAST)
5031 bgp_aggregate_add (bgp, &p, afi, SAFI_MULTICAST, aggregate);
5032
5033 return CMD_SUCCESS;
5034}
5035
94f2b392 5036static int
fd79ac91 5037bgp_aggregate_unset (struct vty *vty, const char *prefix_str,
5038 afi_t afi, safi_t safi)
718e3744 5039{
5040 int ret;
5041 struct prefix p;
5042 struct bgp_node *rn;
5043 struct bgp *bgp;
5044 struct bgp_aggregate *aggregate;
5045
5046 /* Convert string to prefix structure. */
5047 ret = str2prefix (prefix_str, &p);
5048 if (!ret)
5049 {
5050 vty_out (vty, "Malformed prefix%s", VTY_NEWLINE);
5051 return CMD_WARNING;
5052 }
5053 apply_mask (&p);
5054
5055 /* Get BGP structure. */
5056 bgp = vty->index;
5057
5058 /* Old configuration check. */
5059 rn = bgp_node_lookup (bgp->aggregate[afi][safi], &p);
5060 if (! rn)
5061 {
5062 vty_out (vty, "%% There is no aggregate-address configuration.%s",
5063 VTY_NEWLINE);
5064 return CMD_WARNING;
5065 }
5066
5067 aggregate = rn->info;
5068 if (aggregate->safi & SAFI_UNICAST)
5069 bgp_aggregate_delete (bgp, &p, afi, SAFI_UNICAST, aggregate);
5070 if (aggregate->safi & SAFI_MULTICAST)
5071 bgp_aggregate_delete (bgp, &p, afi, SAFI_MULTICAST, aggregate);
5072
5073 /* Unlock aggregate address configuration. */
5074 rn->info = NULL;
5075 bgp_aggregate_free (aggregate);
5076 bgp_unlock_node (rn);
5077 bgp_unlock_node (rn);
5078
5079 return CMD_SUCCESS;
5080}
5081
5082DEFUN (aggregate_address,
5083 aggregate_address_cmd,
5084 "aggregate-address A.B.C.D/M",
5085 "Configure BGP aggregate entries\n"
5086 "Aggregate prefix\n")
5087{
5088 return bgp_aggregate_set (vty, argv[0], AFI_IP, bgp_node_safi (vty), 0, 0);
5089}
5090
5091DEFUN (aggregate_address_mask,
5092 aggregate_address_mask_cmd,
5093 "aggregate-address A.B.C.D A.B.C.D",
5094 "Configure BGP aggregate entries\n"
5095 "Aggregate address\n"
5096 "Aggregate mask\n")
5097{
5098 int ret;
5099 char prefix_str[BUFSIZ];
5100
5101 ret = netmask_str2prefix_str (argv[0], argv[1], prefix_str);
5102
5103 if (! ret)
5104 {
5105 vty_out (vty, "%% Inconsistent address and mask%s", VTY_NEWLINE);
5106 return CMD_WARNING;
5107 }
5108
5109 return bgp_aggregate_set (vty, prefix_str, AFI_IP, bgp_node_safi (vty),
5110 0, 0);
5111}
5112
5113DEFUN (aggregate_address_summary_only,
5114 aggregate_address_summary_only_cmd,
5115 "aggregate-address A.B.C.D/M summary-only",
5116 "Configure BGP aggregate entries\n"
5117 "Aggregate prefix\n"
5118 "Filter more specific routes from updates\n")
5119{
5120 return bgp_aggregate_set (vty, argv[0], AFI_IP, bgp_node_safi (vty),
5121 AGGREGATE_SUMMARY_ONLY, 0);
5122}
5123
5124DEFUN (aggregate_address_mask_summary_only,
5125 aggregate_address_mask_summary_only_cmd,
5126 "aggregate-address A.B.C.D A.B.C.D summary-only",
5127 "Configure BGP aggregate entries\n"
5128 "Aggregate address\n"
5129 "Aggregate mask\n"
5130 "Filter more specific routes from updates\n")
5131{
5132 int ret;
5133 char prefix_str[BUFSIZ];
5134
5135 ret = netmask_str2prefix_str (argv[0], argv[1], prefix_str);
5136
5137 if (! ret)
5138 {
5139 vty_out (vty, "%% Inconsistent address and mask%s", VTY_NEWLINE);
5140 return CMD_WARNING;
5141 }
5142
5143 return bgp_aggregate_set (vty, prefix_str, AFI_IP, bgp_node_safi (vty),
5144 AGGREGATE_SUMMARY_ONLY, 0);
5145}
5146
5147DEFUN (aggregate_address_as_set,
5148 aggregate_address_as_set_cmd,
5149 "aggregate-address A.B.C.D/M as-set",
5150 "Configure BGP aggregate entries\n"
5151 "Aggregate prefix\n"
5152 "Generate AS set path information\n")
5153{
5154 return bgp_aggregate_set (vty, argv[0], AFI_IP, bgp_node_safi (vty),
5155 0, AGGREGATE_AS_SET);
5156}
5157
5158DEFUN (aggregate_address_mask_as_set,
5159 aggregate_address_mask_as_set_cmd,
5160 "aggregate-address A.B.C.D A.B.C.D as-set",
5161 "Configure BGP aggregate entries\n"
5162 "Aggregate address\n"
5163 "Aggregate mask\n"
5164 "Generate AS set path information\n")
5165{
5166 int ret;
5167 char prefix_str[BUFSIZ];
5168
5169 ret = netmask_str2prefix_str (argv[0], argv[1], prefix_str);
5170
5171 if (! ret)
5172 {
5173 vty_out (vty, "%% Inconsistent address and mask%s", VTY_NEWLINE);
5174 return CMD_WARNING;
5175 }
5176
5177 return bgp_aggregate_set (vty, prefix_str, AFI_IP, bgp_node_safi (vty),
5178 0, AGGREGATE_AS_SET);
5179}
5180
5181
5182DEFUN (aggregate_address_as_set_summary,
5183 aggregate_address_as_set_summary_cmd,
5184 "aggregate-address A.B.C.D/M as-set summary-only",
5185 "Configure BGP aggregate entries\n"
5186 "Aggregate prefix\n"
5187 "Generate AS set path information\n"
5188 "Filter more specific routes from updates\n")
5189{
5190 return bgp_aggregate_set (vty, argv[0], AFI_IP, bgp_node_safi (vty),
5191 AGGREGATE_SUMMARY_ONLY, AGGREGATE_AS_SET);
5192}
5193
5194ALIAS (aggregate_address_as_set_summary,
5195 aggregate_address_summary_as_set_cmd,
5196 "aggregate-address A.B.C.D/M summary-only as-set",
5197 "Configure BGP aggregate entries\n"
5198 "Aggregate prefix\n"
5199 "Filter more specific routes from updates\n"
5200 "Generate AS set path information\n")
5201
5202DEFUN (aggregate_address_mask_as_set_summary,
5203 aggregate_address_mask_as_set_summary_cmd,
5204 "aggregate-address A.B.C.D A.B.C.D as-set summary-only",
5205 "Configure BGP aggregate entries\n"
5206 "Aggregate address\n"
5207 "Aggregate mask\n"
5208 "Generate AS set path information\n"
5209 "Filter more specific routes from updates\n")
5210{
5211 int ret;
5212 char prefix_str[BUFSIZ];
5213
5214 ret = netmask_str2prefix_str (argv[0], argv[1], prefix_str);
5215
5216 if (! ret)
5217 {
5218 vty_out (vty, "%% Inconsistent address and mask%s", VTY_NEWLINE);
5219 return CMD_WARNING;
5220 }
5221
5222 return bgp_aggregate_set (vty, prefix_str, AFI_IP, bgp_node_safi (vty),
5223 AGGREGATE_SUMMARY_ONLY, AGGREGATE_AS_SET);
5224}
5225
5226ALIAS (aggregate_address_mask_as_set_summary,
5227 aggregate_address_mask_summary_as_set_cmd,
5228 "aggregate-address A.B.C.D A.B.C.D summary-only as-set",
5229 "Configure BGP aggregate entries\n"
5230 "Aggregate address\n"
5231 "Aggregate mask\n"
5232 "Filter more specific routes from updates\n"
5233 "Generate AS set path information\n")
5234
5235DEFUN (no_aggregate_address,
5236 no_aggregate_address_cmd,
5237 "no aggregate-address A.B.C.D/M",
5238 NO_STR
5239 "Configure BGP aggregate entries\n"
5240 "Aggregate prefix\n")
5241{
5242 return bgp_aggregate_unset (vty, argv[0], AFI_IP, bgp_node_safi (vty));
5243}
5244
5245ALIAS (no_aggregate_address,
5246 no_aggregate_address_summary_only_cmd,
5247 "no aggregate-address A.B.C.D/M summary-only",
5248 NO_STR
5249 "Configure BGP aggregate entries\n"
5250 "Aggregate prefix\n"
5251 "Filter more specific routes from updates\n")
5252
5253ALIAS (no_aggregate_address,
5254 no_aggregate_address_as_set_cmd,
5255 "no aggregate-address A.B.C.D/M as-set",
5256 NO_STR
5257 "Configure BGP aggregate entries\n"
5258 "Aggregate prefix\n"
5259 "Generate AS set path information\n")
5260
5261ALIAS (no_aggregate_address,
5262 no_aggregate_address_as_set_summary_cmd,
5263 "no aggregate-address A.B.C.D/M as-set summary-only",
5264 NO_STR
5265 "Configure BGP aggregate entries\n"
5266 "Aggregate prefix\n"
5267 "Generate AS set path information\n"
5268 "Filter more specific routes from updates\n")
5269
5270ALIAS (no_aggregate_address,
5271 no_aggregate_address_summary_as_set_cmd,
5272 "no aggregate-address A.B.C.D/M summary-only as-set",
5273 NO_STR
5274 "Configure BGP aggregate entries\n"
5275 "Aggregate prefix\n"
5276 "Filter more specific routes from updates\n"
5277 "Generate AS set path information\n")
5278
5279DEFUN (no_aggregate_address_mask,
5280 no_aggregate_address_mask_cmd,
5281 "no aggregate-address A.B.C.D A.B.C.D",
5282 NO_STR
5283 "Configure BGP aggregate entries\n"
5284 "Aggregate address\n"
5285 "Aggregate mask\n")
5286{
5287 int ret;
5288 char prefix_str[BUFSIZ];
5289
5290 ret = netmask_str2prefix_str (argv[0], argv[1], prefix_str);
5291
5292 if (! ret)
5293 {
5294 vty_out (vty, "%% Inconsistent address and mask%s", VTY_NEWLINE);
5295 return CMD_WARNING;
5296 }
5297
5298 return bgp_aggregate_unset (vty, prefix_str, AFI_IP, bgp_node_safi (vty));
5299}
5300
5301ALIAS (no_aggregate_address_mask,
5302 no_aggregate_address_mask_summary_only_cmd,
5303 "no aggregate-address A.B.C.D A.B.C.D summary-only",
5304 NO_STR
5305 "Configure BGP aggregate entries\n"
5306 "Aggregate address\n"
5307 "Aggregate mask\n"
5308 "Filter more specific routes from updates\n")
5309
5310ALIAS (no_aggregate_address_mask,
5311 no_aggregate_address_mask_as_set_cmd,
5312 "no aggregate-address A.B.C.D A.B.C.D as-set",
5313 NO_STR
5314 "Configure BGP aggregate entries\n"
5315 "Aggregate address\n"
5316 "Aggregate mask\n"
5317 "Generate AS set path information\n")
5318
5319ALIAS (no_aggregate_address_mask,
5320 no_aggregate_address_mask_as_set_summary_cmd,
5321 "no aggregate-address A.B.C.D A.B.C.D as-set summary-only",
5322 NO_STR
5323 "Configure BGP aggregate entries\n"
5324 "Aggregate address\n"
5325 "Aggregate mask\n"
5326 "Generate AS set path information\n"
5327 "Filter more specific routes from updates\n")
5328
5329ALIAS (no_aggregate_address_mask,
5330 no_aggregate_address_mask_summary_as_set_cmd,
5331 "no aggregate-address A.B.C.D A.B.C.D summary-only as-set",
5332 NO_STR
5333 "Configure BGP aggregate entries\n"
5334 "Aggregate address\n"
5335 "Aggregate mask\n"
5336 "Filter more specific routes from updates\n"
5337 "Generate AS set path information\n")
5338
5339#ifdef HAVE_IPV6
5340DEFUN (ipv6_aggregate_address,
5341 ipv6_aggregate_address_cmd,
5342 "aggregate-address X:X::X:X/M",
5343 "Configure BGP aggregate entries\n"
5344 "Aggregate prefix\n")
5345{
5346 return bgp_aggregate_set (vty, argv[0], AFI_IP6, SAFI_UNICAST, 0, 0);
5347}
5348
5349DEFUN (ipv6_aggregate_address_summary_only,
5350 ipv6_aggregate_address_summary_only_cmd,
5351 "aggregate-address X:X::X:X/M summary-only",
5352 "Configure BGP aggregate entries\n"
5353 "Aggregate prefix\n"
5354 "Filter more specific routes from updates\n")
5355{
5356 return bgp_aggregate_set (vty, argv[0], AFI_IP6, SAFI_UNICAST,
5357 AGGREGATE_SUMMARY_ONLY, 0);
5358}
5359
5360DEFUN (no_ipv6_aggregate_address,
5361 no_ipv6_aggregate_address_cmd,
5362 "no aggregate-address X:X::X:X/M",
5363 NO_STR
5364 "Configure BGP aggregate entries\n"
5365 "Aggregate prefix\n")
5366{
5367 return bgp_aggregate_unset (vty, argv[0], AFI_IP6, SAFI_UNICAST);
5368}
5369
5370DEFUN (no_ipv6_aggregate_address_summary_only,
5371 no_ipv6_aggregate_address_summary_only_cmd,
5372 "no aggregate-address X:X::X:X/M summary-only",
5373 NO_STR
5374 "Configure BGP aggregate entries\n"
5375 "Aggregate prefix\n"
5376 "Filter more specific routes from updates\n")
5377{
5378 return bgp_aggregate_unset (vty, argv[0], AFI_IP6, SAFI_UNICAST);
5379}
5380
5381ALIAS (ipv6_aggregate_address,
5382 old_ipv6_aggregate_address_cmd,
5383 "ipv6 bgp aggregate-address X:X::X:X/M",
5384 IPV6_STR
5385 BGP_STR
5386 "Configure BGP aggregate entries\n"
5387 "Aggregate prefix\n")
5388
5389ALIAS (ipv6_aggregate_address_summary_only,
5390 old_ipv6_aggregate_address_summary_only_cmd,
5391 "ipv6 bgp aggregate-address X:X::X:X/M summary-only",
5392 IPV6_STR
5393 BGP_STR
5394 "Configure BGP aggregate entries\n"
5395 "Aggregate prefix\n"
5396 "Filter more specific routes from updates\n")
5397
5398ALIAS (no_ipv6_aggregate_address,
5399 old_no_ipv6_aggregate_address_cmd,
5400 "no ipv6 bgp aggregate-address X:X::X:X/M",
5401 NO_STR
5402 IPV6_STR
5403 BGP_STR
5404 "Configure BGP aggregate entries\n"
5405 "Aggregate prefix\n")
5406
5407ALIAS (no_ipv6_aggregate_address_summary_only,
5408 old_no_ipv6_aggregate_address_summary_only_cmd,
5409 "no ipv6 bgp aggregate-address X:X::X:X/M summary-only",
5410 NO_STR
5411 IPV6_STR
5412 BGP_STR
5413 "Configure BGP aggregate entries\n"
5414 "Aggregate prefix\n"
5415 "Filter more specific routes from updates\n")
5416#endif /* HAVE_IPV6 */
5417\f
5418/* Redistribute route treatment. */
5419void
5420bgp_redistribute_add (struct prefix *p, struct in_addr *nexthop,
5421 u_int32_t metric, u_char type)
5422{
5423 struct bgp *bgp;
1eb8ef25 5424 struct listnode *node, *nnode;
718e3744 5425 struct bgp_info *new;
5426 struct bgp_info *bi;
5427 struct bgp_info info;
5428 struct bgp_node *bn;
fb982c25
PJ
5429 struct attr attr = { 0 };
5430 struct attr attr_new = { 0 };
718e3744 5431 struct attr *new_attr;
5432 afi_t afi;
5433 int ret;
5434
5435 /* Make default attribute. */
5436 bgp_attr_default_set (&attr, BGP_ORIGIN_INCOMPLETE);
5437 if (nexthop)
5438 attr.nexthop = *nexthop;
5439
5440 attr.med = metric;
5441 attr.flag |= ATTR_FLAG_BIT (BGP_ATTR_MULTI_EXIT_DISC);
5442
1eb8ef25 5443 for (ALL_LIST_ELEMENTS (bm->bgp, node, nnode, bgp))
718e3744 5444 {
5445 afi = family2afi (p->family);
5446
5447 if (bgp->redist[afi][type])
5448 {
5449 /* Copy attribute for modification. */
fb982c25 5450 bgp_attr_dup (&attr_new, &attr);
718e3744 5451
5452 if (bgp->redist_metric_flag[afi][type])
5453 attr_new.med = bgp->redist_metric[afi][type];
5454
5455 /* Apply route-map. */
5456 if (bgp->rmap[afi][type].map)
5457 {
5458 info.peer = bgp->peer_self;
5459 info.attr = &attr_new;
5460
fee0f4c6 5461 SET_FLAG (bgp->peer_self->rmap_type, PEER_RMAP_TYPE_REDISTRIBUTE);
5462
718e3744 5463 ret = route_map_apply (bgp->rmap[afi][type].map, p, RMAP_BGP,
5464 &info);
fee0f4c6 5465
5466 bgp->peer_self->rmap_type = 0;
5467
718e3744 5468 if (ret == RMAP_DENYMATCH)
5469 {
5470 /* Free uninterned attribute. */
5471 bgp_attr_flush (&attr_new);
fb982c25
PJ
5472 bgp_attr_extra_free (&attr_new);
5473
718e3744 5474 /* Unintern original. */
5475 aspath_unintern (attr.aspath);
fb982c25 5476 bgp_attr_extra_free (&attr);
718e3744 5477 bgp_redistribute_delete (p, type);
5478 return;
5479 }
5480 }
5481
fb982c25
PJ
5482 bn = bgp_afi_node_get (bgp->rib[afi][SAFI_UNICAST],
5483 afi, SAFI_UNICAST, p, NULL);
5484
718e3744 5485 new_attr = bgp_attr_intern (&attr_new);
fb982c25
PJ
5486 bgp_attr_extra_free (&attr_new);
5487
718e3744 5488 for (bi = bn->info; bi; bi = bi->next)
5489 if (bi->peer == bgp->peer_self
5490 && bi->sub_type == BGP_ROUTE_REDISTRIBUTE)
5491 break;
5492
5493 if (bi)
5494 {
8d45210e
AS
5495 if (attrhash_cmp (bi->attr, new_attr) &&
5496 !CHECK_FLAG(bi->flags, BGP_INFO_REMOVED))
718e3744 5497 {
5498 bgp_attr_unintern (new_attr);
5499 aspath_unintern (attr.aspath);
fb982c25 5500 bgp_attr_extra_free (&attr);
718e3744 5501 bgp_unlock_node (bn);
5502 return;
5503 }
5504 else
5505 {
5506 /* The attribute is changed. */
1a392d46 5507 bgp_info_set_flag (bn, bi, BGP_INFO_ATTR_CHANGED);
718e3744 5508
5509 /* Rewrite BGP route information. */
8d45210e
AS
5510 if (CHECK_FLAG(bi->flags, BGP_INFO_REMOVED))
5511 bgp_info_restore(bn, bi);
5512 else
5513 bgp_aggregate_decrement (bgp, p, bi, afi, SAFI_UNICAST);
718e3744 5514 bgp_attr_unintern (bi->attr);
5515 bi->attr = new_attr;
65957886 5516 bi->uptime = bgp_clock ();
718e3744 5517
5518 /* Process change. */
5519 bgp_aggregate_increment (bgp, p, bi, afi, SAFI_UNICAST);
5520 bgp_process (bgp, bn, afi, SAFI_UNICAST);
5521 bgp_unlock_node (bn);
5522 aspath_unintern (attr.aspath);
fb982c25 5523 bgp_attr_extra_free (&attr);
718e3744 5524 return;
5525 }
5526 }
5527
5528 new = bgp_info_new ();
5529 new->type = type;
5530 new->sub_type = BGP_ROUTE_REDISTRIBUTE;
5531 new->peer = bgp->peer_self;
5532 SET_FLAG (new->flags, BGP_INFO_VALID);
5533 new->attr = new_attr;
65957886 5534 new->uptime = bgp_clock ();
718e3744 5535
5536 bgp_aggregate_increment (bgp, p, new, afi, SAFI_UNICAST);
5537 bgp_info_add (bn, new);
200df115 5538 bgp_unlock_node (bn);
718e3744 5539 bgp_process (bgp, bn, afi, SAFI_UNICAST);
5540 }
5541 }
5542
5543 /* Unintern original. */
5544 aspath_unintern (attr.aspath);
fb982c25 5545 bgp_attr_extra_free (&attr);
718e3744 5546}
5547
5548void
5549bgp_redistribute_delete (struct prefix *p, u_char type)
5550{
5551 struct bgp *bgp;
1eb8ef25 5552 struct listnode *node, *nnode;
718e3744 5553 afi_t afi;
5554 struct bgp_node *rn;
5555 struct bgp_info *ri;
5556
1eb8ef25 5557 for (ALL_LIST_ELEMENTS (bm->bgp, node, nnode, bgp))
718e3744 5558 {
5559 afi = family2afi (p->family);
5560
5561 if (bgp->redist[afi][type])
5562 {
fee0f4c6 5563 rn = bgp_afi_node_get (bgp->rib[afi][SAFI_UNICAST], afi, SAFI_UNICAST, p, NULL);
718e3744 5564
5565 for (ri = rn->info; ri; ri = ri->next)
5566 if (ri->peer == bgp->peer_self
5567 && ri->type == type)
5568 break;
5569
5570 if (ri)
5571 {
5572 bgp_aggregate_decrement (bgp, p, ri, afi, SAFI_UNICAST);
718e3744 5573 bgp_info_delete (rn, ri);
1a392d46 5574 bgp_process (bgp, rn, afi, SAFI_UNICAST);
718e3744 5575 }
5576 bgp_unlock_node (rn);
5577 }
5578 }
5579}
5580
5581/* Withdraw specified route type's route. */
5582void
5583bgp_redistribute_withdraw (struct bgp *bgp, afi_t afi, int type)
5584{
5585 struct bgp_node *rn;
5586 struct bgp_info *ri;
5587 struct bgp_table *table;
5588
5589 table = bgp->rib[afi][SAFI_UNICAST];
5590
5591 for (rn = bgp_table_top (table); rn; rn = bgp_route_next (rn))
5592 {
5593 for (ri = rn->info; ri; ri = ri->next)
5594 if (ri->peer == bgp->peer_self
5595 && ri->type == type)
5596 break;
5597
5598 if (ri)
5599 {
5600 bgp_aggregate_decrement (bgp, &rn->p, ri, afi, SAFI_UNICAST);
718e3744 5601 bgp_info_delete (rn, ri);
1a392d46 5602 bgp_process (bgp, rn, afi, SAFI_UNICAST);
718e3744 5603 }
5604 }
5605}
5606\f
5607/* Static function to display route. */
94f2b392 5608static void
718e3744 5609route_vty_out_route (struct prefix *p, struct vty *vty)
5610{
5611 int len;
5612 u_int32_t destination;
5613 char buf[BUFSIZ];
5614
5615 if (p->family == AF_INET)
5616 {
5617 len = vty_out (vty, "%s", inet_ntop (p->family, &p->u.prefix, buf, BUFSIZ));
5618 destination = ntohl (p->u.prefix4.s_addr);
5619
5620 if ((IN_CLASSC (destination) && p->prefixlen == 24)
5621 || (IN_CLASSB (destination) && p->prefixlen == 16)
5622 || (IN_CLASSA (destination) && p->prefixlen == 8)
5623 || p->u.prefix4.s_addr == 0)
5624 {
5625 /* When mask is natural, mask is not displayed. */
5626 }
5627 else
5628 len += vty_out (vty, "/%d", p->prefixlen);
5629 }
5630 else
5631 len = vty_out (vty, "%s/%d", inet_ntop (p->family, &p->u.prefix, buf, BUFSIZ),
5632 p->prefixlen);
5633
5634 len = 17 - len;
5635 if (len < 1)
5636 vty_out (vty, "%s%*s", VTY_NEWLINE, 20, " ");
5637 else
5638 vty_out (vty, "%*s", len, " ");
5639}
5640
718e3744 5641enum bgp_display_type
5642{
5643 normal_list,
5644};
5645
b40d939b 5646/* Print the short form route status for a bgp_info */
5647static void
5648route_vty_short_status_out (struct vty *vty, struct bgp_info *binfo)
718e3744 5649{
b40d939b 5650 /* Route status display. */
5651 if (CHECK_FLAG (binfo->flags, BGP_INFO_REMOVED))
5652 vty_out (vty, "R");
5653 else if (CHECK_FLAG (binfo->flags, BGP_INFO_STALE))
93406d87 5654 vty_out (vty, "S");
fb982c25 5655 else if (binfo->extra && binfo->extra->suppress)
718e3744 5656 vty_out (vty, "s");
5657 else if (! CHECK_FLAG (binfo->flags, BGP_INFO_HISTORY))
5658 vty_out (vty, "*");
5659 else
5660 vty_out (vty, " ");
5661
5662 /* Selected */
5663 if (CHECK_FLAG (binfo->flags, BGP_INFO_HISTORY))
5664 vty_out (vty, "h");
5665 else if (CHECK_FLAG (binfo->flags, BGP_INFO_DAMPED))
5666 vty_out (vty, "d");
5667 else if (CHECK_FLAG (binfo->flags, BGP_INFO_SELECTED))
5668 vty_out (vty, ">");
5669 else
5670 vty_out (vty, " ");
5671
5672 /* Internal route. */
5673 if ((binfo->peer->as) && (binfo->peer->as == binfo->peer->local_as))
5674 vty_out (vty, "i");
5675 else
b40d939b 5676 vty_out (vty, " ");
5677}
5678
5679/* called from terminal list command */
5680void
5681route_vty_out (struct vty *vty, struct prefix *p,
5682 struct bgp_info *binfo, int display, safi_t safi)
5683{
5684 struct attr *attr;
5685
5686 /* short status lead text */
5687 route_vty_short_status_out (vty, binfo);
718e3744 5688
5689 /* print prefix and mask */
5690 if (! display)
5691 route_vty_out_route (p, vty);
5692 else
5693 vty_out (vty, "%*s", 17, " ");
5694
5695 /* Print attribute */
5696 attr = binfo->attr;
5697 if (attr)
5698 {
5699 if (p->family == AF_INET)
5700 {
5701 if (safi == SAFI_MPLS_VPN)
fb982c25
PJ
5702 vty_out (vty, "%-16s",
5703 inet_ntoa (attr->extra->mp_nexthop_global_in));
718e3744 5704 else
5705 vty_out (vty, "%-16s", inet_ntoa (attr->nexthop));
5706 }
5707#ifdef HAVE_IPV6
5708 else if (p->family == AF_INET6)
5709 {
5710 int len;
5711 char buf[BUFSIZ];
5712
5713 len = vty_out (vty, "%s",
fb982c25
PJ
5714 inet_ntop (AF_INET6, &attr->extra->mp_nexthop_global,
5715 buf, BUFSIZ));
718e3744 5716 len = 16 - len;
5717 if (len < 1)
5718 vty_out (vty, "%s%*s", VTY_NEWLINE, 36, " ");
5719 else
5720 vty_out (vty, "%*s", len, " ");
5721 }
5722#endif /* HAVE_IPV6 */
5723
5724 if (attr->flag & ATTR_FLAG_BIT (BGP_ATTR_MULTI_EXIT_DISC))
5725 vty_out (vty, "%10d", attr->med);
5726 else
5727 vty_out (vty, " ");
5728
5729 if (attr->flag & ATTR_FLAG_BIT (BGP_ATTR_LOCAL_PREF))
5730 vty_out (vty, "%7d", attr->local_pref);
5731 else
5732 vty_out (vty, " ");
5733
fb982c25 5734 vty_out (vty, "%7u ", (attr->extra ? attr->extra->weight : 0));
718e3744 5735
b2518c1e
PJ
5736 /* Print aspath */
5737 if (attr->aspath)
841f7a57 5738 aspath_print_vty (vty, "%s", attr->aspath, " ");
718e3744 5739
b2518c1e 5740 /* Print origin */
718e3744 5741 vty_out (vty, "%s", bgp_origin_str[attr->origin]);
b2518c1e 5742 }
718e3744 5743 vty_out (vty, "%s", VTY_NEWLINE);
718e3744 5744}
5745
5746/* called from terminal list command */
5747void
5748route_vty_out_tmp (struct vty *vty, struct prefix *p,
5749 struct attr *attr, safi_t safi)
5750{
5751 /* Route status display. */
5752 vty_out (vty, "*");
5753 vty_out (vty, ">");
5754 vty_out (vty, " ");
5755
5756 /* print prefix and mask */
5757 route_vty_out_route (p, vty);
5758
5759 /* Print attribute */
5760 if (attr)
5761 {
5762 if (p->family == AF_INET)
5763 {
5764 if (safi == SAFI_MPLS_VPN)
fb982c25
PJ
5765 vty_out (vty, "%-16s",
5766 inet_ntoa (attr->extra->mp_nexthop_global_in));
718e3744 5767 else
5768 vty_out (vty, "%-16s", inet_ntoa (attr->nexthop));
5769 }
5770#ifdef HAVE_IPV6
5771 else if (p->family == AF_INET6)
5772 {
5773 int len;
5774 char buf[BUFSIZ];
fb982c25
PJ
5775
5776 assert (attr->extra);
718e3744 5777
5778 len = vty_out (vty, "%s",
fb982c25
PJ
5779 inet_ntop (AF_INET6, &attr->extra->mp_nexthop_global,
5780 buf, BUFSIZ));
718e3744 5781 len = 16 - len;
5782 if (len < 1)
5783 vty_out (vty, "%s%*s", VTY_NEWLINE, 36, " ");
5784 else
5785 vty_out (vty, "%*s", len, " ");
5786 }
5787#endif /* HAVE_IPV6 */
5788
5789 if (attr->flag & ATTR_FLAG_BIT (BGP_ATTR_MULTI_EXIT_DISC))
5790 vty_out (vty, "%10d", attr->med);
5791 else
5792 vty_out (vty, " ");
5793
5794 if (attr->flag & ATTR_FLAG_BIT (BGP_ATTR_LOCAL_PREF))
5795 vty_out (vty, "%7d", attr->local_pref);
5796 else
5797 vty_out (vty, " ");
fb982c25
PJ
5798
5799 vty_out (vty, "%7d ", (attr->extra ? attr->extra->weight : 0));
5800
b2518c1e
PJ
5801 /* Print aspath */
5802 if (attr->aspath)
841f7a57 5803 aspath_print_vty (vty, "%s", attr->aspath, " ");
718e3744 5804
b2518c1e 5805 /* Print origin */
718e3744 5806 vty_out (vty, "%s", bgp_origin_str[attr->origin]);
b2518c1e 5807 }
718e3744 5808
5809 vty_out (vty, "%s", VTY_NEWLINE);
5810}
5811
5a646650 5812void
718e3744 5813route_vty_out_tag (struct vty *vty, struct prefix *p,
5814 struct bgp_info *binfo, int display, safi_t safi)
5815{
5816 struct attr *attr;
718e3744 5817 u_int32_t label = 0;
fb982c25
PJ
5818
5819 if (!binfo->extra)
5820 return;
5821
b40d939b 5822 /* short status lead text */
5823 route_vty_short_status_out (vty, binfo);
5824
718e3744 5825 /* print prefix and mask */
5826 if (! display)
5827 route_vty_out_route (p, vty);
5828 else
5829 vty_out (vty, "%*s", 17, " ");
5830
5831 /* Print attribute */
5832 attr = binfo->attr;
5833 if (attr)
5834 {
5835 if (p->family == AF_INET)
5836 {
5837 if (safi == SAFI_MPLS_VPN)
fb982c25
PJ
5838 vty_out (vty, "%-16s",
5839 inet_ntoa (attr->extra->mp_nexthop_global_in));
718e3744 5840 else
5841 vty_out (vty, "%-16s", inet_ntoa (attr->nexthop));
5842 }
5843#ifdef HAVE_IPV6
5844 else if (p->family == AF_INET6)
5845 {
fb982c25 5846 assert (attr->extra);
718e3744 5847 char buf[BUFSIZ];
5848 char buf1[BUFSIZ];
fb982c25 5849 if (attr->extra->mp_nexthop_len == 16)
718e3744 5850 vty_out (vty, "%s",
fb982c25
PJ
5851 inet_ntop (AF_INET6, &attr->extra->mp_nexthop_global,
5852 buf, BUFSIZ));
5853 else if (attr->extra->mp_nexthop_len == 32)
718e3744 5854 vty_out (vty, "%s(%s)",
fb982c25
PJ
5855 inet_ntop (AF_INET6, &attr->extra->mp_nexthop_global,
5856 buf, BUFSIZ),
5857 inet_ntop (AF_INET6, &attr->extra->mp_nexthop_local,
5858 buf1, BUFSIZ));
718e3744 5859
5860 }
5861#endif /* HAVE_IPV6 */
5862 }
5863
fb982c25 5864 label = decode_label (binfo->extra->tag);
718e3744 5865
5866 vty_out (vty, "notag/%d", label);
5867
5868 vty_out (vty, "%s", VTY_NEWLINE);
718e3744 5869}
5870
5871/* dampening route */
5a646650 5872static void
718e3744 5873damp_route_vty_out (struct vty *vty, struct prefix *p,
5874 struct bgp_info *binfo, int display, safi_t safi)
5875{
5876 struct attr *attr;
718e3744 5877 int len;
50aef6f3 5878 char timebuf[BGP_UPTIME_LEN];
718e3744 5879
b40d939b 5880 /* short status lead text */
5881 route_vty_short_status_out (vty, binfo);
5882
718e3744 5883 /* print prefix and mask */
5884 if (! display)
5885 route_vty_out_route (p, vty);
5886 else
5887 vty_out (vty, "%*s", 17, " ");
5888
5889 len = vty_out (vty, "%s", binfo->peer->host);
5890 len = 17 - len;
5891 if (len < 1)
5892 vty_out (vty, "%s%*s", VTY_NEWLINE, 34, " ");
5893 else
5894 vty_out (vty, "%*s", len, " ");
5895
50aef6f3 5896 vty_out (vty, "%s ", bgp_damp_reuse_time_vty (vty, binfo, timebuf, BGP_UPTIME_LEN));
718e3744 5897
5898 /* Print attribute */
5899 attr = binfo->attr;
5900 if (attr)
5901 {
5902 /* Print aspath */
5903 if (attr->aspath)
841f7a57 5904 aspath_print_vty (vty, "%s", attr->aspath, " ");
718e3744 5905
5906 /* Print origin */
b2518c1e 5907 vty_out (vty, "%s", bgp_origin_str[attr->origin]);
718e3744 5908 }
5909 vty_out (vty, "%s", VTY_NEWLINE);
718e3744 5910}
5911
718e3744 5912/* flap route */
5a646650 5913static void
718e3744 5914flap_route_vty_out (struct vty *vty, struct prefix *p,
5915 struct bgp_info *binfo, int display, safi_t safi)
5916{
5917 struct attr *attr;
5918 struct bgp_damp_info *bdi;
718e3744 5919 char timebuf[BGP_UPTIME_LEN];
5920 int len;
fb982c25
PJ
5921
5922 if (!binfo->extra)
5923 return;
5924
5925 bdi = binfo->extra->damp_info;
718e3744 5926
b40d939b 5927 /* short status lead text */
5928 route_vty_short_status_out (vty, binfo);
5929
718e3744 5930 /* print prefix and mask */
5931 if (! display)
5932 route_vty_out_route (p, vty);
5933 else
5934 vty_out (vty, "%*s", 17, " ");
5935
5936 len = vty_out (vty, "%s", binfo->peer->host);
5937 len = 16 - len;
5938 if (len < 1)
5939 vty_out (vty, "%s%*s", VTY_NEWLINE, 33, " ");
5940 else
5941 vty_out (vty, "%*s", len, " ");
5942
5943 len = vty_out (vty, "%d", bdi->flap);
5944 len = 5 - len;
5945 if (len < 1)
5946 vty_out (vty, " ");
5947 else
5948 vty_out (vty, "%*s ", len, " ");
5949
5950 vty_out (vty, "%s ", peer_uptime (bdi->start_time,
5951 timebuf, BGP_UPTIME_LEN));
5952
5953 if (CHECK_FLAG (binfo->flags, BGP_INFO_DAMPED)
5954 && ! CHECK_FLAG (binfo->flags, BGP_INFO_HISTORY))
50aef6f3 5955 vty_out (vty, "%s ", bgp_damp_reuse_time_vty (vty, binfo, timebuf, BGP_UPTIME_LEN));
718e3744 5956 else
5957 vty_out (vty, "%*s ", 8, " ");
5958
5959 /* Print attribute */
5960 attr = binfo->attr;
5961 if (attr)
5962 {
5963 /* Print aspath */
5964 if (attr->aspath)
841f7a57 5965 aspath_print_vty (vty, "%s", attr->aspath, " ");
718e3744 5966
5967 /* Print origin */
b2518c1e 5968 vty_out (vty, "%s", bgp_origin_str[attr->origin]);
718e3744 5969 }
5970 vty_out (vty, "%s", VTY_NEWLINE);
718e3744 5971}
5972
94f2b392 5973static void
718e3744 5974route_vty_out_detail (struct vty *vty, struct bgp *bgp, struct prefix *p,
5975 struct bgp_info *binfo, afi_t afi, safi_t safi)
5976{
5977 char buf[INET6_ADDRSTRLEN];
5978 char buf1[BUFSIZ];
5979 struct attr *attr;
5980 int sockunion_vty_out (struct vty *, union sockunion *);
30b00176
JK
5981#ifdef HAVE_CLOCK_MONOTONIC
5982 time_t tbuf;
5983#endif
718e3744 5984
5985 attr = binfo->attr;
5986
5987 if (attr)
5988 {
5989 /* Line1 display AS-path, Aggregator */
5990 if (attr->aspath)
5991 {
5992 vty_out (vty, " ");
fe69a505 5993 if (aspath_count_hops (attr->aspath) == 0)
718e3744 5994 vty_out (vty, "Local");
5995 else
841f7a57 5996 aspath_print_vty (vty, "%s", attr->aspath, "");
718e3744 5997 }
5998
b40d939b 5999 if (CHECK_FLAG (binfo->flags, BGP_INFO_REMOVED))
6000 vty_out (vty, ", (removed)");
93406d87 6001 if (CHECK_FLAG (binfo->flags, BGP_INFO_STALE))
6002 vty_out (vty, ", (stale)");
6003 if (CHECK_FLAG (attr->flag, ATTR_FLAG_BIT (BGP_ATTR_AGGREGATOR)))
aea339f7 6004 vty_out (vty, ", (aggregated by %u %s)",
fb982c25
PJ
6005 attr->extra->aggregator_as,
6006 inet_ntoa (attr->extra->aggregator_addr));
93406d87 6007 if (CHECK_FLAG (binfo->peer->af_flags[afi][safi], PEER_FLAG_REFLECTOR_CLIENT))
6008 vty_out (vty, ", (Received from a RR-client)");
6009 if (CHECK_FLAG (binfo->peer->af_flags[afi][safi], PEER_FLAG_RSERVER_CLIENT))
6010 vty_out (vty, ", (Received from a RS-client)");
6011 if (CHECK_FLAG (binfo->flags, BGP_INFO_HISTORY))
6012 vty_out (vty, ", (history entry)");
6013 else if (CHECK_FLAG (binfo->flags, BGP_INFO_DAMPED))
6014 vty_out (vty, ", (suppressed due to dampening)");
718e3744 6015 vty_out (vty, "%s", VTY_NEWLINE);
6016
6017 /* Line2 display Next-hop, Neighbor, Router-id */
6018 if (p->family == AF_INET)
6019 {
6020 vty_out (vty, " %s", safi == SAFI_MPLS_VPN ?
fb982c25 6021 inet_ntoa (attr->extra->mp_nexthop_global_in) :
718e3744 6022 inet_ntoa (attr->nexthop));
6023 }
6024#ifdef HAVE_IPV6
6025 else
6026 {
fb982c25 6027 assert (attr->extra);
718e3744 6028 vty_out (vty, " %s",
fb982c25 6029 inet_ntop (AF_INET6, &attr->extra->mp_nexthop_global,
718e3744 6030 buf, INET6_ADDRSTRLEN));
6031 }
6032#endif /* HAVE_IPV6 */
6033
6034 if (binfo->peer == bgp->peer_self)
6035 {
6036 vty_out (vty, " from %s ",
6037 p->family == AF_INET ? "0.0.0.0" : "::");
6038 vty_out (vty, "(%s)", inet_ntoa(bgp->router_id));
6039 }
6040 else
6041 {
6042 if (! CHECK_FLAG (binfo->flags, BGP_INFO_VALID))
6043 vty_out (vty, " (inaccessible)");
fb982c25
PJ
6044 else if (binfo->extra && binfo->extra->igpmetric)
6045 vty_out (vty, " (metric %d)", binfo->extra->igpmetric);
eb821189 6046 vty_out (vty, " from %s", sockunion2str (&binfo->peer->su, buf, SU_ADDRSTRLEN));
718e3744 6047 if (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_ORIGINATOR_ID))
fb982c25 6048 vty_out (vty, " (%s)", inet_ntoa (attr->extra->originator_id));
718e3744 6049 else
6050 vty_out (vty, " (%s)", inet_ntop (AF_INET, &binfo->peer->remote_id, buf1, BUFSIZ));
6051 }
6052 vty_out (vty, "%s", VTY_NEWLINE);
6053
6054#ifdef HAVE_IPV6
6055 /* display nexthop local */
fb982c25 6056 if (attr->extra && attr->extra->mp_nexthop_len == 32)
718e3744 6057 {
6058 vty_out (vty, " (%s)%s",
fb982c25 6059 inet_ntop (AF_INET6, &attr->extra->mp_nexthop_local,
718e3744 6060 buf, INET6_ADDRSTRLEN),
6061 VTY_NEWLINE);
6062 }
6063#endif /* HAVE_IPV6 */
6064
6065 /* Line 3 display Origin, Med, Locpref, Weight, valid, Int/Ext/Local, Atomic, best */
6066 vty_out (vty, " Origin %s", bgp_origin_long_str[attr->origin]);
6067
6068 if (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_MULTI_EXIT_DISC))
6069 vty_out (vty, ", metric %d", attr->med);
6070
6071 if (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_LOCAL_PREF))
6072 vty_out (vty, ", localpref %d", attr->local_pref);
6073 else
6074 vty_out (vty, ", localpref %d", bgp->default_local_pref);
6075
fb982c25
PJ
6076 if (attr->extra && attr->extra->weight != 0)
6077 vty_out (vty, ", weight %d", attr->extra->weight);
718e3744 6078
6079 if (! CHECK_FLAG (binfo->flags, BGP_INFO_HISTORY))
6080 vty_out (vty, ", valid");
6081
6082 if (binfo->peer != bgp->peer_self)
6083 {
6084 if (binfo->peer->as == binfo->peer->local_as)
6085 vty_out (vty, ", internal");
6086 else
6087 vty_out (vty, ", %s",
6088 (bgp_confederation_peers_check(bgp, binfo->peer->as) ? "confed-external" : "external"));
6089 }
6090 else if (binfo->sub_type == BGP_ROUTE_AGGREGATE)
6091 vty_out (vty, ", aggregated, local");
6092 else if (binfo->type != ZEBRA_ROUTE_BGP)
6093 vty_out (vty, ", sourced");
6094 else
6095 vty_out (vty, ", sourced, local");
6096
6097 if (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_ATOMIC_AGGREGATE))
6098 vty_out (vty, ", atomic-aggregate");
6099
6100 if (CHECK_FLAG (binfo->flags, BGP_INFO_SELECTED))
6101 vty_out (vty, ", best");
6102
6103 vty_out (vty, "%s", VTY_NEWLINE);
6104
6105 /* Line 4 display Community */
6106 if (attr->community)
6107 vty_out (vty, " Community: %s%s", attr->community->str,
6108 VTY_NEWLINE);
6109
6110 /* Line 5 display Extended-community */
6111 if (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_EXT_COMMUNITIES))
fb982c25
PJ
6112 vty_out (vty, " Extended Community: %s%s",
6113 attr->extra->ecommunity->str, VTY_NEWLINE);
718e3744 6114
6115 /* Line 6 display Originator, Cluster-id */
6116 if ((attr->flag & ATTR_FLAG_BIT(BGP_ATTR_ORIGINATOR_ID)) ||
6117 (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_CLUSTER_LIST)))
6118 {
fb982c25 6119 assert (attr->extra);
718e3744 6120 if (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_ORIGINATOR_ID))
fb982c25
PJ
6121 vty_out (vty, " Originator: %s",
6122 inet_ntoa (attr->extra->originator_id));
718e3744 6123
6124 if (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_CLUSTER_LIST))
6125 {
6126 int i;
6127 vty_out (vty, ", Cluster list: ");
fb982c25
PJ
6128 for (i = 0; i < attr->extra->cluster->length / 4; i++)
6129 vty_out (vty, "%s ",
6130 inet_ntoa (attr->extra->cluster->list[i]));
718e3744 6131 }
6132 vty_out (vty, "%s", VTY_NEWLINE);
6133 }
41367172
PJ
6134
6135 /* 7: AS Pathlimit */
6136 if (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_AS_PATHLIMIT))
6137 {
6138
6139 vty_out (vty, " AS-Pathlimit: %u",
6140 attr->pathlimit.ttl);
6141 if (attr->pathlimit.as)
6142 vty_out (vty, " (%u)", attr->pathlimit.as);
6143 vty_out (vty, "%s", VTY_NEWLINE);
6144 }
6145
fb982c25 6146 if (binfo->extra && binfo->extra->damp_info)
718e3744 6147 bgp_damp_info_vty (vty, binfo);
6148
6149 /* Line 7 display Uptime */
30b00176
JK
6150#ifdef HAVE_CLOCK_MONOTONIC
6151 tbuf = time(NULL) - (bgp_clock() - binfo->uptime);
213b6cd9 6152 vty_out (vty, " Last update: %s", ctime(&tbuf));
30b00176
JK
6153#else
6154 vty_out (vty, " Last update: %s", ctime(&binfo->uptime));
6155#endif /* HAVE_CLOCK_MONOTONIC */
718e3744 6156 }
6157 vty_out (vty, "%s", VTY_NEWLINE);
6158}
6159\f
b40d939b 6160#define BGP_SHOW_SCODE_HEADER "Status codes: s suppressed, d damped, h history, * valid, > best, i - internal,%s r RIB-failure, S Stale, R Removed%s"
93406d87 6161#define BGP_SHOW_OCODE_HEADER "Origin codes: i - IGP, e - EGP, ? - incomplete%s%s"
718e3744 6162#define BGP_SHOW_HEADER " Network Next Hop Metric LocPrf Weight Path%s"
6163#define BGP_SHOW_DAMP_HEADER " Network From Reuse Path%s"
6164#define BGP_SHOW_FLAP_HEADER " Network From Flaps Duration Reuse Path%s"
6165
6166enum bgp_show_type
6167{
6168 bgp_show_type_normal,
6169 bgp_show_type_regexp,
6170 bgp_show_type_prefix_list,
6171 bgp_show_type_filter_list,
6172 bgp_show_type_route_map,
6173 bgp_show_type_neighbor,
6174 bgp_show_type_cidr_only,
6175 bgp_show_type_prefix_longer,
6176 bgp_show_type_community_all,
6177 bgp_show_type_community,
6178 bgp_show_type_community_exact,
6179 bgp_show_type_community_list,
6180 bgp_show_type_community_list_exact,
6181 bgp_show_type_flap_statistics,
6182 bgp_show_type_flap_address,
6183 bgp_show_type_flap_prefix,
6184 bgp_show_type_flap_cidr_only,
6185 bgp_show_type_flap_regexp,
6186 bgp_show_type_flap_filter_list,
6187 bgp_show_type_flap_prefix_list,
6188 bgp_show_type_flap_prefix_longer,
6189 bgp_show_type_flap_route_map,
6190 bgp_show_type_flap_neighbor,
6191 bgp_show_type_dampend_paths,
6192 bgp_show_type_damp_neighbor
6193};
6194
5a646650 6195static int
fee0f4c6 6196bgp_show_table (struct vty *vty, struct bgp_table *table, struct in_addr *router_id,
5a646650 6197 enum bgp_show_type type, void *output_arg)
718e3744 6198{
718e3744 6199 struct bgp_info *ri;
6200 struct bgp_node *rn;
718e3744 6201 int header = 1;
718e3744 6202 int display;
5a646650 6203 unsigned long output_count;
718e3744 6204
6205 /* This is first entry point, so reset total line. */
5a646650 6206 output_count = 0;
718e3744 6207
718e3744 6208 /* Start processing of routes. */
6209 for (rn = bgp_table_top (table); rn; rn = bgp_route_next (rn))
6210 if (rn->info != NULL)
6211 {
6212 display = 0;
6213
6214 for (ri = rn->info; ri; ri = ri->next)
6215 {
5a646650 6216 if (type == bgp_show_type_flap_statistics
718e3744 6217 || type == bgp_show_type_flap_address
6218 || type == bgp_show_type_flap_prefix
6219 || type == bgp_show_type_flap_cidr_only
6220 || type == bgp_show_type_flap_regexp
6221 || type == bgp_show_type_flap_filter_list
6222 || type == bgp_show_type_flap_prefix_list
6223 || type == bgp_show_type_flap_prefix_longer
6224 || type == bgp_show_type_flap_route_map
6225 || type == bgp_show_type_flap_neighbor
6226 || type == bgp_show_type_dampend_paths
6227 || type == bgp_show_type_damp_neighbor)
6228 {
fb982c25 6229 if (!(ri->extra && ri->extra->damp_info))
718e3744 6230 continue;
6231 }
6232 if (type == bgp_show_type_regexp
6233 || type == bgp_show_type_flap_regexp)
6234 {
5a646650 6235 regex_t *regex = output_arg;
718e3744 6236
6237 if (bgp_regexec (regex, ri->attr->aspath) == REG_NOMATCH)
6238 continue;
6239 }
6240 if (type == bgp_show_type_prefix_list
6241 || type == bgp_show_type_flap_prefix_list)
6242 {
5a646650 6243 struct prefix_list *plist = output_arg;
718e3744 6244
6245 if (prefix_list_apply (plist, &rn->p) != PREFIX_PERMIT)
6246 continue;
6247 }
6248 if (type == bgp_show_type_filter_list
6249 || type == bgp_show_type_flap_filter_list)
6250 {
5a646650 6251 struct as_list *as_list = output_arg;
718e3744 6252
6253 if (as_list_apply (as_list, ri->attr->aspath) != AS_FILTER_PERMIT)
6254 continue;
6255 }
6256 if (type == bgp_show_type_route_map
6257 || type == bgp_show_type_flap_route_map)
6258 {
5a646650 6259 struct route_map *rmap = output_arg;
718e3744 6260 struct bgp_info binfo;
9eda90ce 6261 struct attr dummy_attr = { 0 };
718e3744 6262 int ret;
6263
fb982c25 6264 bgp_attr_dup (&dummy_attr, ri->attr);
718e3744 6265 binfo.peer = ri->peer;
6266 binfo.attr = &dummy_attr;
6267
6268 ret = route_map_apply (rmap, &rn->p, RMAP_BGP, &binfo);
fb982c25
PJ
6269
6270 bgp_attr_extra_free (&dummy_attr);
6271
718e3744 6272 if (ret == RMAP_DENYMATCH)
6273 continue;
6274 }
6275 if (type == bgp_show_type_neighbor
6276 || type == bgp_show_type_flap_neighbor
6277 || type == bgp_show_type_damp_neighbor)
6278 {
5a646650 6279 union sockunion *su = output_arg;
718e3744 6280
6281 if (ri->peer->su_remote == NULL || ! sockunion_same(ri->peer->su_remote, su))
6282 continue;
6283 }
6284 if (type == bgp_show_type_cidr_only
6285 || type == bgp_show_type_flap_cidr_only)
6286 {
6287 u_int32_t destination;
6288
6289 destination = ntohl (rn->p.u.prefix4.s_addr);
6290 if (IN_CLASSC (destination) && rn->p.prefixlen == 24)
6291 continue;
6292 if (IN_CLASSB (destination) && rn->p.prefixlen == 16)
6293 continue;
6294 if (IN_CLASSA (destination) && rn->p.prefixlen == 8)
6295 continue;
6296 }
6297 if (type == bgp_show_type_prefix_longer
6298 || type == bgp_show_type_flap_prefix_longer)
6299 {
5a646650 6300 struct prefix *p = output_arg;
718e3744 6301
6302 if (! prefix_match (p, &rn->p))
6303 continue;
6304 }
6305 if (type == bgp_show_type_community_all)
6306 {
6307 if (! ri->attr->community)
6308 continue;
6309 }
6310 if (type == bgp_show_type_community)
6311 {
5a646650 6312 struct community *com = output_arg;
718e3744 6313
6314 if (! ri->attr->community ||
6315 ! community_match (ri->attr->community, com))
6316 continue;
6317 }
6318 if (type == bgp_show_type_community_exact)
6319 {
5a646650 6320 struct community *com = output_arg;
718e3744 6321
6322 if (! ri->attr->community ||
6323 ! community_cmp (ri->attr->community, com))
6324 continue;
6325 }
6326 if (type == bgp_show_type_community_list)
6327 {
5a646650 6328 struct community_list *list = output_arg;
718e3744 6329
6330 if (! community_list_match (ri->attr->community, list))
6331 continue;
6332 }
6333 if (type == bgp_show_type_community_list_exact)
6334 {
5a646650 6335 struct community_list *list = output_arg;
718e3744 6336
6337 if (! community_list_exact_match (ri->attr->community, list))
6338 continue;
6339 }
6340 if (type == bgp_show_type_flap_address
6341 || type == bgp_show_type_flap_prefix)
6342 {
5a646650 6343 struct prefix *p = output_arg;
718e3744 6344
6345 if (! prefix_match (&rn->p, p))
6346 continue;
6347
6348 if (type == bgp_show_type_flap_prefix)
6349 if (p->prefixlen != rn->p.prefixlen)
6350 continue;
6351 }
6352 if (type == bgp_show_type_dampend_paths
6353 || type == bgp_show_type_damp_neighbor)
6354 {
6355 if (! CHECK_FLAG (ri->flags, BGP_INFO_DAMPED)
6356 || CHECK_FLAG (ri->flags, BGP_INFO_HISTORY))
6357 continue;
6358 }
6359
6360 if (header)
6361 {
93406d87 6362 vty_out (vty, "BGP table version is 0, local router ID is %s%s", inet_ntoa (*router_id), VTY_NEWLINE);
6363 vty_out (vty, BGP_SHOW_SCODE_HEADER, VTY_NEWLINE, VTY_NEWLINE);
6364 vty_out (vty, BGP_SHOW_OCODE_HEADER, VTY_NEWLINE, VTY_NEWLINE);
718e3744 6365 if (type == bgp_show_type_dampend_paths
6366 || type == bgp_show_type_damp_neighbor)
6367 vty_out (vty, BGP_SHOW_DAMP_HEADER, VTY_NEWLINE);
6368 else if (type == bgp_show_type_flap_statistics
6369 || type == bgp_show_type_flap_address
6370 || type == bgp_show_type_flap_prefix
6371 || type == bgp_show_type_flap_cidr_only
6372 || type == bgp_show_type_flap_regexp
6373 || type == bgp_show_type_flap_filter_list
6374 || type == bgp_show_type_flap_prefix_list
6375 || type == bgp_show_type_flap_prefix_longer
6376 || type == bgp_show_type_flap_route_map
6377 || type == bgp_show_type_flap_neighbor)
6378 vty_out (vty, BGP_SHOW_FLAP_HEADER, VTY_NEWLINE);
6379 else
6380 vty_out (vty, BGP_SHOW_HEADER, VTY_NEWLINE);
718e3744 6381 header = 0;
6382 }
6383
6384 if (type == bgp_show_type_dampend_paths
6385 || type == bgp_show_type_damp_neighbor)
5a646650 6386 damp_route_vty_out (vty, &rn->p, ri, display, SAFI_UNICAST);
718e3744 6387 else if (type == bgp_show_type_flap_statistics
6388 || type == bgp_show_type_flap_address
6389 || type == bgp_show_type_flap_prefix
6390 || type == bgp_show_type_flap_cidr_only
6391 || type == bgp_show_type_flap_regexp
6392 || type == bgp_show_type_flap_filter_list
6393 || type == bgp_show_type_flap_prefix_list
6394 || type == bgp_show_type_flap_prefix_longer
6395 || type == bgp_show_type_flap_route_map
6396 || type == bgp_show_type_flap_neighbor)
5a646650 6397 flap_route_vty_out (vty, &rn->p, ri, display, SAFI_UNICAST);
718e3744 6398 else
5a646650 6399 route_vty_out (vty, &rn->p, ri, display, SAFI_UNICAST);
718e3744 6400 display++;
6401 }
6402 if (display)
5a646650 6403 output_count++;
718e3744 6404 }
6405
6406 /* No route is displayed */
5a646650 6407 if (output_count == 0)
718e3744 6408 {
6409 if (type == bgp_show_type_normal)
6410 vty_out (vty, "No BGP network exists%s", VTY_NEWLINE);
6411 }
6412 else
6413 vty_out (vty, "%sTotal number of prefixes %ld%s",
5a646650 6414 VTY_NEWLINE, output_count, VTY_NEWLINE);
718e3744 6415
6416 return CMD_SUCCESS;
6417}
6418
5a646650 6419static int
fee0f4c6 6420bgp_show (struct vty *vty, struct bgp *bgp, afi_t afi, safi_t safi,
5a646650 6421 enum bgp_show_type type, void *output_arg)
fee0f4c6 6422{
6423 struct bgp_table *table;
6424
6425 if (bgp == NULL) {
6426 bgp = bgp_get_default ();
6427 }
6428
6429 if (bgp == NULL)
6430 {
6431 vty_out (vty, "No BGP process is configured%s", VTY_NEWLINE);
6432 return CMD_WARNING;
6433 }
6434
6435
6436 table = bgp->rib[afi][safi];
6437
5a646650 6438 return bgp_show_table (vty, table, &bgp->router_id, type, output_arg);
fee0f4c6 6439}
6440
718e3744 6441/* Header of detailed BGP route information */
94f2b392 6442static void
718e3744 6443route_vty_out_detail_header (struct vty *vty, struct bgp *bgp,
6444 struct bgp_node *rn,
6445 struct prefix_rd *prd, afi_t afi, safi_t safi)
6446{
6447 struct bgp_info *ri;
6448 struct prefix *p;
6449 struct peer *peer;
1eb8ef25 6450 struct listnode *node, *nnode;
718e3744 6451 char buf1[INET6_ADDRSTRLEN];
6452 char buf2[INET6_ADDRSTRLEN];
6453 int count = 0;
6454 int best = 0;
6455 int suppress = 0;
6456 int no_export = 0;
6457 int no_advertise = 0;
6458 int local_as = 0;
6459 int first = 0;
6460
6461 p = &rn->p;
6462 vty_out (vty, "BGP routing table entry for %s%s%s/%d%s",
6463 (safi == SAFI_MPLS_VPN ?
6464 prefix_rd2str (prd, buf1, RD_ADDRSTRLEN) : ""),
6465 safi == SAFI_MPLS_VPN ? ":" : "",
6466 inet_ntop (p->family, &p->u.prefix, buf2, INET6_ADDRSTRLEN),
6467 p->prefixlen, VTY_NEWLINE);
6468
6469 for (ri = rn->info; ri; ri = ri->next)
6470 {
6471 count++;
6472 if (CHECK_FLAG (ri->flags, BGP_INFO_SELECTED))
6473 {
6474 best = count;
fb982c25 6475 if (ri->extra && ri->extra->suppress)
718e3744 6476 suppress = 1;
6477 if (ri->attr->community != NULL)
6478 {
6479 if (community_include (ri->attr->community, COMMUNITY_NO_ADVERTISE))
6480 no_advertise = 1;
6481 if (community_include (ri->attr->community, COMMUNITY_NO_EXPORT))
6482 no_export = 1;
6483 if (community_include (ri->attr->community, COMMUNITY_LOCAL_AS))
6484 local_as = 1;
6485 }
6486 }
6487 }
6488
6489 vty_out (vty, "Paths: (%d available", count);
6490 if (best)
6491 {
6492 vty_out (vty, ", best #%d", best);
6493 if (safi == SAFI_UNICAST)
6494 vty_out (vty, ", table Default-IP-Routing-Table");
6495 }
6496 else
6497 vty_out (vty, ", no best path");
6498 if (no_advertise)
6499 vty_out (vty, ", not advertised to any peer");
6500 else if (no_export)
6501 vty_out (vty, ", not advertised to EBGP peer");
6502 else if (local_as)
6503 vty_out (vty, ", not advertised outside local AS");
6504 if (suppress)
6505 vty_out (vty, ", Advertisements suppressed by an aggregate.");
6506 vty_out (vty, ")%s", VTY_NEWLINE);
6507
6508 /* advertised peer */
1eb8ef25 6509 for (ALL_LIST_ELEMENTS (bgp->peer, node, nnode, peer))
718e3744 6510 {
6511 if (bgp_adj_out_lookup (peer, p, afi, safi, rn))
6512 {
6513 if (! first)
6514 vty_out (vty, " Advertised to non peer-group peers:%s ", VTY_NEWLINE);
6515 vty_out (vty, " %s", sockunion2str (&peer->su, buf1, SU_ADDRSTRLEN));
6516 first = 1;
6517 }
6518 }
6519 if (! first)
6520 vty_out (vty, " Not advertised to any peer");
6521 vty_out (vty, "%s", VTY_NEWLINE);
6522}
6523
6524/* Display specified route of BGP table. */
94f2b392 6525static int
fee0f4c6 6526bgp_show_route_in_table (struct vty *vty, struct bgp *bgp,
fd79ac91 6527 struct bgp_table *rib, const char *ip_str,
6528 afi_t afi, safi_t safi, struct prefix_rd *prd,
6529 int prefix_check)
718e3744 6530{
6531 int ret;
6532 int header;
6533 int display = 0;
6534 struct prefix match;
6535 struct bgp_node *rn;
6536 struct bgp_node *rm;
6537 struct bgp_info *ri;
718e3744 6538 struct bgp_table *table;
6539
718e3744 6540 /* Check IP address argument. */
6541 ret = str2prefix (ip_str, &match);
6542 if (! ret)
6543 {
6544 vty_out (vty, "address is malformed%s", VTY_NEWLINE);
6545 return CMD_WARNING;
6546 }
6547
6548 match.family = afi2family (afi);
6549
6550 if (safi == SAFI_MPLS_VPN)
6551 {
fee0f4c6 6552 for (rn = bgp_table_top (rib); rn; rn = bgp_route_next (rn))
718e3744 6553 {
6554 if (prd && memcmp (rn->p.u.val, prd->val, 8) != 0)
6555 continue;
6556
6557 if ((table = rn->info) != NULL)
6558 {
6559 header = 1;
6560
6561 if ((rm = bgp_node_match (table, &match)) != NULL)
6562 {
6563 if (prefix_check && rm->p.prefixlen != match.prefixlen)
6564 continue;
6565
6566 for (ri = rm->info; ri; ri = ri->next)
6567 {
6568 if (header)
6569 {
6570 route_vty_out_detail_header (vty, bgp, rm, (struct prefix_rd *)&rn->p,
6571 AFI_IP, SAFI_MPLS_VPN);
6572
6573 header = 0;
6574 }
6575 display++;
6576 route_vty_out_detail (vty, bgp, &rm->p, ri, AFI_IP, SAFI_MPLS_VPN);
6577 }
6578 }
6579 }
6580 }
6581 }
6582 else
6583 {
6584 header = 1;
6585
fee0f4c6 6586 if ((rn = bgp_node_match (rib, &match)) != NULL)
718e3744 6587 {
6588 if (! prefix_check || rn->p.prefixlen == match.prefixlen)
6589 {
6590 for (ri = rn->info; ri; ri = ri->next)
6591 {
6592 if (header)
6593 {
6594 route_vty_out_detail_header (vty, bgp, rn, NULL, afi, safi);
6595 header = 0;
6596 }
6597 display++;
6598 route_vty_out_detail (vty, bgp, &rn->p, ri, afi, safi);
6599 }
6600 }
6601 }
6602 }
6603
6604 if (! display)
6605 {
6606 vty_out (vty, "%% Network not in table%s", VTY_NEWLINE);
6607 return CMD_WARNING;
6608 }
6609
6610 return CMD_SUCCESS;
6611}
6612
fee0f4c6 6613/* Display specified route of Main RIB */
94f2b392 6614static int
fd79ac91 6615bgp_show_route (struct vty *vty, const char *view_name, const char *ip_str,
fee0f4c6 6616 afi_t afi, safi_t safi, struct prefix_rd *prd,
6617 int prefix_check)
6618{
6619 struct bgp *bgp;
6620
6621 /* BGP structure lookup. */
6622 if (view_name)
6623 {
6624 bgp = bgp_lookup_by_name (view_name);
6625 if (bgp == NULL)
6626 {
6627 vty_out (vty, "Can't find BGP view %s%s", view_name, VTY_NEWLINE);
6628 return CMD_WARNING;
6629 }
6630 }
6631 else
6632 {
6633 bgp = bgp_get_default ();
6634 if (bgp == NULL)
6635 {
6636 vty_out (vty, "No BGP process is configured%s", VTY_NEWLINE);
6637 return CMD_WARNING;
6638 }
6639 }
6640
6641 return bgp_show_route_in_table (vty, bgp, bgp->rib[afi][safi], ip_str,
6642 afi, safi, prd, prefix_check);
6643}
6644
718e3744 6645/* BGP route print out function. */
6646DEFUN (show_ip_bgp,
6647 show_ip_bgp_cmd,
6648 "show ip bgp",
6649 SHOW_STR
6650 IP_STR
6651 BGP_STR)
6652{
5a646650 6653 return bgp_show (vty, NULL, AFI_IP, SAFI_UNICAST, bgp_show_type_normal, NULL);
718e3744 6654}
6655
6656DEFUN (show_ip_bgp_ipv4,
6657 show_ip_bgp_ipv4_cmd,
6658 "show ip bgp ipv4 (unicast|multicast)",
6659 SHOW_STR
6660 IP_STR
6661 BGP_STR
6662 "Address family\n"
6663 "Address Family modifier\n"
6664 "Address Family modifier\n")
6665{
6666 if (strncmp (argv[0], "m", 1) == 0)
5a646650 6667 return bgp_show (vty, NULL, AFI_IP, SAFI_MULTICAST, bgp_show_type_normal,
6668 NULL);
718e3744 6669
5a646650 6670 return bgp_show (vty, NULL, AFI_IP, SAFI_UNICAST, bgp_show_type_normal, NULL);
718e3744 6671}
6672
6673DEFUN (show_ip_bgp_route,
6674 show_ip_bgp_route_cmd,
6675 "show ip bgp A.B.C.D",
6676 SHOW_STR
6677 IP_STR
6678 BGP_STR
6679 "Network in the BGP routing table to display\n")
6680{
6681 return bgp_show_route (vty, NULL, argv[0], AFI_IP, SAFI_UNICAST, NULL, 0);
6682}
6683
6684DEFUN (show_ip_bgp_ipv4_route,
6685 show_ip_bgp_ipv4_route_cmd,
6686 "show ip bgp ipv4 (unicast|multicast) A.B.C.D",
6687 SHOW_STR
6688 IP_STR
6689 BGP_STR
6690 "Address family\n"
6691 "Address Family modifier\n"
6692 "Address Family modifier\n"
6693 "Network in the BGP routing table to display\n")
6694{
6695 if (strncmp (argv[0], "m", 1) == 0)
6696 return bgp_show_route (vty, NULL, argv[1], AFI_IP, SAFI_MULTICAST, NULL, 0);
6697
6698 return bgp_show_route (vty, NULL, argv[1], AFI_IP, SAFI_UNICAST, NULL, 0);
6699}
6700
6701DEFUN (show_ip_bgp_vpnv4_all_route,
6702 show_ip_bgp_vpnv4_all_route_cmd,
6703 "show ip bgp vpnv4 all A.B.C.D",
6704 SHOW_STR
6705 IP_STR
6706 BGP_STR
6707 "Display VPNv4 NLRI specific information\n"
6708 "Display information about all VPNv4 NLRIs\n"
6709 "Network in the BGP routing table to display\n")
6710{
6711 return bgp_show_route (vty, NULL, argv[0], AFI_IP, SAFI_MPLS_VPN, NULL, 0);
6712}
6713
6714DEFUN (show_ip_bgp_vpnv4_rd_route,
6715 show_ip_bgp_vpnv4_rd_route_cmd,
6716 "show ip bgp vpnv4 rd ASN:nn_or_IP-address:nn A.B.C.D",
6717 SHOW_STR
6718 IP_STR
6719 BGP_STR
6720 "Display VPNv4 NLRI specific information\n"
6721 "Display information for a route distinguisher\n"
6722 "VPN Route Distinguisher\n"
6723 "Network in the BGP routing table to display\n")
6724{
6725 int ret;
6726 struct prefix_rd prd;
6727
6728 ret = str2prefix_rd (argv[0], &prd);
6729 if (! ret)
6730 {
6731 vty_out (vty, "%% Malformed Route Distinguisher%s", VTY_NEWLINE);
6732 return CMD_WARNING;
6733 }
6734 return bgp_show_route (vty, NULL, argv[1], AFI_IP, SAFI_MPLS_VPN, &prd, 0);
6735}
6736
6737DEFUN (show_ip_bgp_prefix,
6738 show_ip_bgp_prefix_cmd,
6739 "show ip bgp A.B.C.D/M",
6740 SHOW_STR
6741 IP_STR
6742 BGP_STR
6743 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n")
6744{
6745 return bgp_show_route (vty, NULL, argv[0], AFI_IP, SAFI_UNICAST, NULL, 1);
6746}
6747
6748DEFUN (show_ip_bgp_ipv4_prefix,
6749 show_ip_bgp_ipv4_prefix_cmd,
6750 "show ip bgp ipv4 (unicast|multicast) A.B.C.D/M",
6751 SHOW_STR
6752 IP_STR
6753 BGP_STR
6754 "Address family\n"
6755 "Address Family modifier\n"
6756 "Address Family modifier\n"
6757 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n")
6758{
6759 if (strncmp (argv[0], "m", 1) == 0)
6760 return bgp_show_route (vty, NULL, argv[1], AFI_IP, SAFI_MULTICAST, NULL, 1);
6761
6762 return bgp_show_route (vty, NULL, argv[1], AFI_IP, SAFI_UNICAST, NULL, 1);
6763}
6764
6765DEFUN (show_ip_bgp_vpnv4_all_prefix,
6766 show_ip_bgp_vpnv4_all_prefix_cmd,
6767 "show ip bgp vpnv4 all A.B.C.D/M",
6768 SHOW_STR
6769 IP_STR
6770 BGP_STR
6771 "Display VPNv4 NLRI specific information\n"
6772 "Display information about all VPNv4 NLRIs\n"
6773 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n")
6774{
6775 return bgp_show_route (vty, NULL, argv[0], AFI_IP, SAFI_MPLS_VPN, NULL, 1);
6776}
6777
6778DEFUN (show_ip_bgp_vpnv4_rd_prefix,
6779 show_ip_bgp_vpnv4_rd_prefix_cmd,
6780 "show ip bgp vpnv4 rd ASN:nn_or_IP-address:nn A.B.C.D/M",
6781 SHOW_STR
6782 IP_STR
6783 BGP_STR
6784 "Display VPNv4 NLRI specific information\n"
6785 "Display information for a route distinguisher\n"
6786 "VPN Route Distinguisher\n"
6787 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n")
6788{
6789 int ret;
6790 struct prefix_rd prd;
6791
6792 ret = str2prefix_rd (argv[0], &prd);
6793 if (! ret)
6794 {
6795 vty_out (vty, "%% Malformed Route Distinguisher%s", VTY_NEWLINE);
6796 return CMD_WARNING;
6797 }
6798 return bgp_show_route (vty, NULL, argv[1], AFI_IP, SAFI_MPLS_VPN, &prd, 1);
6799}
6800
6801DEFUN (show_ip_bgp_view,
6802 show_ip_bgp_view_cmd,
6803 "show ip bgp view WORD",
6804 SHOW_STR
6805 IP_STR
6806 BGP_STR
6807 "BGP view\n"
6808 "BGP view name\n")
6809{
bb46e94f 6810 struct bgp *bgp;
6811
6812 /* BGP structure lookup. */
6813 bgp = bgp_lookup_by_name (argv[0]);
6814 if (bgp == NULL)
6815 {
6816 vty_out (vty, "Can't find BGP view %s%s", argv[0], VTY_NEWLINE);
6817 return CMD_WARNING;
6818 }
6819
5a646650 6820 return bgp_show (vty, bgp, AFI_IP, SAFI_UNICAST, bgp_show_type_normal, NULL);
718e3744 6821}
6822
6823DEFUN (show_ip_bgp_view_route,
6824 show_ip_bgp_view_route_cmd,
6825 "show ip bgp view WORD A.B.C.D",
6826 SHOW_STR
6827 IP_STR
6828 BGP_STR
6829 "BGP view\n"
6830 "BGP view name\n"
6831 "Network in the BGP routing table to display\n")
6832{
6833 return bgp_show_route (vty, argv[0], argv[1], AFI_IP, SAFI_UNICAST, NULL, 0);
6834}
6835
6836DEFUN (show_ip_bgp_view_prefix,
6837 show_ip_bgp_view_prefix_cmd,
6838 "show ip bgp view WORD A.B.C.D/M",
6839 SHOW_STR
6840 IP_STR
6841 BGP_STR
6842 "BGP view\n"
6843 "BGP view name\n"
6844 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n")
6845{
6846 return bgp_show_route (vty, argv[0], argv[1], AFI_IP, SAFI_UNICAST, NULL, 1);
6847}
6848
6849#ifdef HAVE_IPV6
6850DEFUN (show_bgp,
6851 show_bgp_cmd,
6852 "show bgp",
6853 SHOW_STR
6854 BGP_STR)
6855{
5a646650 6856 return bgp_show (vty, NULL, AFI_IP6, SAFI_UNICAST, bgp_show_type_normal,
6857 NULL);
718e3744 6858}
6859
6860ALIAS (show_bgp,
6861 show_bgp_ipv6_cmd,
6862 "show bgp ipv6",
6863 SHOW_STR
6864 BGP_STR
6865 "Address family\n")
6866
6867/* old command */
6868DEFUN (show_ipv6_bgp,
6869 show_ipv6_bgp_cmd,
6870 "show ipv6 bgp",
6871 SHOW_STR
6872 IP_STR
6873 BGP_STR)
6874{
5a646650 6875 return bgp_show (vty, NULL, AFI_IP6, SAFI_UNICAST, bgp_show_type_normal,
6876 NULL);
718e3744 6877}
6878
6879DEFUN (show_bgp_route,
6880 show_bgp_route_cmd,
6881 "show bgp X:X::X:X",
6882 SHOW_STR
6883 BGP_STR
6884 "Network in the BGP routing table to display\n")
6885{
6886 return bgp_show_route (vty, NULL, argv[0], AFI_IP6, SAFI_UNICAST, NULL, 0);
6887}
6888
6889ALIAS (show_bgp_route,
6890 show_bgp_ipv6_route_cmd,
6891 "show bgp ipv6 X:X::X:X",
6892 SHOW_STR
6893 BGP_STR
6894 "Address family\n"
6895 "Network in the BGP routing table to display\n")
6896
6897/* old command */
6898DEFUN (show_ipv6_bgp_route,
6899 show_ipv6_bgp_route_cmd,
6900 "show ipv6 bgp X:X::X:X",
6901 SHOW_STR
6902 IP_STR
6903 BGP_STR
6904 "Network in the BGP routing table to display\n")
6905{
6906 return bgp_show_route (vty, NULL, argv[0], AFI_IP6, SAFI_UNICAST, NULL, 0);
6907}
6908
6909DEFUN (show_bgp_prefix,
6910 show_bgp_prefix_cmd,
6911 "show bgp X:X::X:X/M",
6912 SHOW_STR
6913 BGP_STR
6914 "IPv6 prefix <network>/<length>\n")
6915{
6916 return bgp_show_route (vty, NULL, argv[0], AFI_IP6, SAFI_UNICAST, NULL, 1);
6917}
6918
6919ALIAS (show_bgp_prefix,
6920 show_bgp_ipv6_prefix_cmd,
6921 "show bgp ipv6 X:X::X:X/M",
6922 SHOW_STR
6923 BGP_STR
6924 "Address family\n"
6925 "IPv6 prefix <network>/<length>\n")
6926
6927/* old command */
6928DEFUN (show_ipv6_bgp_prefix,
6929 show_ipv6_bgp_prefix_cmd,
6930 "show ipv6 bgp X:X::X:X/M",
6931 SHOW_STR
6932 IP_STR
6933 BGP_STR
6934 "IPv6 prefix <network>/<length>, e.g., 3ffe::/16\n")
6935{
6936 return bgp_show_route (vty, NULL, argv[0], AFI_IP6, SAFI_UNICAST, NULL, 1);
6937}
6938
bb46e94f 6939DEFUN (show_bgp_view,
6940 show_bgp_view_cmd,
6941 "show bgp view WORD",
6942 SHOW_STR
6943 BGP_STR
6944 "BGP view\n"
6945 "View name\n")
6946{
6947 struct bgp *bgp;
6948
6949 /* BGP structure lookup. */
6950 bgp = bgp_lookup_by_name (argv[0]);
6951 if (bgp == NULL)
6952 {
6953 vty_out (vty, "Can't find BGP view %s%s", argv[0], VTY_NEWLINE);
6954 return CMD_WARNING;
6955 }
6956
5a646650 6957 return bgp_show (vty, bgp, AFI_IP6, SAFI_UNICAST, bgp_show_type_normal, NULL);
bb46e94f 6958}
6959
6960ALIAS (show_bgp_view,
6961 show_bgp_view_ipv6_cmd,
6962 "show bgp view WORD ipv6",
6963 SHOW_STR
6964 BGP_STR
6965 "BGP view\n"
6966 "View name\n"
6967 "Address family\n")
6968
6969DEFUN (show_bgp_view_route,
6970 show_bgp_view_route_cmd,
6971 "show bgp view WORD X:X::X:X",
6972 SHOW_STR
6973 BGP_STR
6974 "BGP view\n"
6975 "View name\n"
6976 "Network in the BGP routing table to display\n")
6977{
6978 return bgp_show_route (vty, argv[0], argv[1], AFI_IP6, SAFI_UNICAST, NULL, 0);
6979}
6980
6981ALIAS (show_bgp_view_route,
6982 show_bgp_view_ipv6_route_cmd,
6983 "show bgp view WORD ipv6 X:X::X:X",
6984 SHOW_STR
6985 BGP_STR
6986 "BGP view\n"
6987 "View name\n"
6988 "Address family\n"
6989 "Network in the BGP routing table to display\n")
6990
6991DEFUN (show_bgp_view_prefix,
6992 show_bgp_view_prefix_cmd,
6993 "show bgp view WORD X:X::X:X/M",
6994 SHOW_STR
6995 BGP_STR
6996 "BGP view\n"
6997 "View name\n"
6998 "IPv6 prefix <network>/<length>\n")
6999{
7000 return bgp_show_route (vty, argv[0], argv[1], AFI_IP6, SAFI_UNICAST, NULL, 1);
7001}
7002
7003ALIAS (show_bgp_view_prefix,
7004 show_bgp_view_ipv6_prefix_cmd,
7005 "show bgp view WORD ipv6 X:X::X:X/M",
7006 SHOW_STR
7007 BGP_STR
7008 "BGP view\n"
7009 "View name\n"
7010 "Address family\n"
7011 "IPv6 prefix <network>/<length>\n")
7012
718e3744 7013/* old command */
7014DEFUN (show_ipv6_mbgp,
7015 show_ipv6_mbgp_cmd,
7016 "show ipv6 mbgp",
7017 SHOW_STR
7018 IP_STR
7019 MBGP_STR)
7020{
5a646650 7021 return bgp_show (vty, NULL, AFI_IP6, SAFI_MULTICAST, bgp_show_type_normal,
7022 NULL);
718e3744 7023}
7024
7025/* old command */
7026DEFUN (show_ipv6_mbgp_route,
7027 show_ipv6_mbgp_route_cmd,
7028 "show ipv6 mbgp X:X::X:X",
7029 SHOW_STR
7030 IP_STR
7031 MBGP_STR
7032 "Network in the MBGP routing table to display\n")
7033{
7034 return bgp_show_route (vty, NULL, argv[0], AFI_IP6, SAFI_MULTICAST, NULL, 0);
7035}
7036
7037/* old command */
7038DEFUN (show_ipv6_mbgp_prefix,
7039 show_ipv6_mbgp_prefix_cmd,
7040 "show ipv6 mbgp X:X::X:X/M",
7041 SHOW_STR
7042 IP_STR
7043 MBGP_STR
7044 "IPv6 prefix <network>/<length>, e.g., 3ffe::/16\n")
7045{
7046 return bgp_show_route (vty, NULL, argv[0], AFI_IP6, SAFI_MULTICAST, NULL, 1);
7047}
7048#endif
7049\f
718e3744 7050
94f2b392 7051static int
fd79ac91 7052bgp_show_regexp (struct vty *vty, int argc, const char **argv, afi_t afi,
718e3744 7053 safi_t safi, enum bgp_show_type type)
7054{
7055 int i;
7056 struct buffer *b;
7057 char *regstr;
7058 int first;
7059 regex_t *regex;
5a646650 7060 int rc;
718e3744 7061
7062 first = 0;
7063 b = buffer_new (1024);
7064 for (i = 0; i < argc; i++)
7065 {
7066 if (first)
7067 buffer_putc (b, ' ');
7068 else
7069 {
7070 if ((strcmp (argv[i], "unicast") == 0) || (strcmp (argv[i], "multicast") == 0))
7071 continue;
7072 first = 1;
7073 }
7074
7075 buffer_putstr (b, argv[i]);
7076 }
7077 buffer_putc (b, '\0');
7078
7079 regstr = buffer_getstr (b);
7080 buffer_free (b);
7081
7082 regex = bgp_regcomp (regstr);
3b8b1855 7083 XFREE(MTYPE_TMP, regstr);
718e3744 7084 if (! regex)
7085 {
7086 vty_out (vty, "Can't compile regexp %s%s", argv[0],
7087 VTY_NEWLINE);
7088 return CMD_WARNING;
7089 }
7090
5a646650 7091 rc = bgp_show (vty, NULL, afi, safi, type, regex);
7092 bgp_regex_free (regex);
7093 return rc;
718e3744 7094}
7095
7096DEFUN (show_ip_bgp_regexp,
7097 show_ip_bgp_regexp_cmd,
7098 "show ip bgp regexp .LINE",
7099 SHOW_STR
7100 IP_STR
7101 BGP_STR
7102 "Display routes matching the AS path regular expression\n"
7103 "A regular-expression to match the BGP AS paths\n")
7104{
7105 return bgp_show_regexp (vty, argc, argv, AFI_IP, SAFI_UNICAST,
7106 bgp_show_type_regexp);
7107}
7108
7109DEFUN (show_ip_bgp_flap_regexp,
7110 show_ip_bgp_flap_regexp_cmd,
7111 "show ip bgp flap-statistics regexp .LINE",
7112 SHOW_STR
7113 IP_STR
7114 BGP_STR
7115 "Display flap statistics of routes\n"
7116 "Display routes matching the AS path regular expression\n"
7117 "A regular-expression to match the BGP AS paths\n")
7118{
7119 return bgp_show_regexp (vty, argc, argv, AFI_IP, SAFI_UNICAST,
7120 bgp_show_type_flap_regexp);
7121}
7122
7123DEFUN (show_ip_bgp_ipv4_regexp,
7124 show_ip_bgp_ipv4_regexp_cmd,
7125 "show ip bgp ipv4 (unicast|multicast) regexp .LINE",
7126 SHOW_STR
7127 IP_STR
7128 BGP_STR
7129 "Address family\n"
7130 "Address Family modifier\n"
7131 "Address Family modifier\n"
7132 "Display routes matching the AS path regular expression\n"
7133 "A regular-expression to match the BGP AS paths\n")
7134{
7135 if (strncmp (argv[0], "m", 1) == 0)
7136 return bgp_show_regexp (vty, argc, argv, AFI_IP, SAFI_MULTICAST,
7137 bgp_show_type_regexp);
7138
7139 return bgp_show_regexp (vty, argc, argv, AFI_IP, SAFI_UNICAST,
7140 bgp_show_type_regexp);
7141}
7142
7143#ifdef HAVE_IPV6
7144DEFUN (show_bgp_regexp,
7145 show_bgp_regexp_cmd,
7146 "show bgp regexp .LINE",
7147 SHOW_STR
7148 BGP_STR
7149 "Display routes matching the AS path regular expression\n"
7150 "A regular-expression to match the BGP AS paths\n")
7151{
7152 return bgp_show_regexp (vty, argc, argv, AFI_IP6, SAFI_UNICAST,
7153 bgp_show_type_regexp);
7154}
7155
7156ALIAS (show_bgp_regexp,
7157 show_bgp_ipv6_regexp_cmd,
7158 "show bgp ipv6 regexp .LINE",
7159 SHOW_STR
7160 BGP_STR
7161 "Address family\n"
7162 "Display routes matching the AS path regular expression\n"
7163 "A regular-expression to match the BGP AS paths\n")
7164
7165/* old command */
7166DEFUN (show_ipv6_bgp_regexp,
7167 show_ipv6_bgp_regexp_cmd,
7168 "show ipv6 bgp regexp .LINE",
7169 SHOW_STR
7170 IP_STR
7171 BGP_STR
7172 "Display routes matching the AS path regular expression\n"
7173 "A regular-expression to match the BGP AS paths\n")
7174{
7175 return bgp_show_regexp (vty, argc, argv, AFI_IP6, SAFI_UNICAST,
7176 bgp_show_type_regexp);
7177}
7178
7179/* old command */
7180DEFUN (show_ipv6_mbgp_regexp,
7181 show_ipv6_mbgp_regexp_cmd,
7182 "show ipv6 mbgp regexp .LINE",
7183 SHOW_STR
7184 IP_STR
7185 BGP_STR
7186 "Display routes matching the AS path regular expression\n"
7187 "A regular-expression to match the MBGP AS paths\n")
7188{
7189 return bgp_show_regexp (vty, argc, argv, AFI_IP6, SAFI_MULTICAST,
7190 bgp_show_type_regexp);
7191}
7192#endif /* HAVE_IPV6 */
7193\f
94f2b392 7194static int
fd79ac91 7195bgp_show_prefix_list (struct vty *vty, const char *prefix_list_str, afi_t afi,
718e3744 7196 safi_t safi, enum bgp_show_type type)
7197{
7198 struct prefix_list *plist;
7199
7200 plist = prefix_list_lookup (afi, prefix_list_str);
7201 if (plist == NULL)
7202 {
7203 vty_out (vty, "%% %s is not a valid prefix-list name%s",
7204 prefix_list_str, VTY_NEWLINE);
7205 return CMD_WARNING;
7206 }
7207
5a646650 7208 return bgp_show (vty, NULL, afi, safi, type, plist);
718e3744 7209}
7210
7211DEFUN (show_ip_bgp_prefix_list,
7212 show_ip_bgp_prefix_list_cmd,
7213 "show ip bgp prefix-list WORD",
7214 SHOW_STR
7215 IP_STR
7216 BGP_STR
7217 "Display routes conforming to the prefix-list\n"
7218 "IP prefix-list name\n")
7219{
7220 return bgp_show_prefix_list (vty, argv[0], AFI_IP, SAFI_UNICAST,
7221 bgp_show_type_prefix_list);
7222}
7223
7224DEFUN (show_ip_bgp_flap_prefix_list,
7225 show_ip_bgp_flap_prefix_list_cmd,
7226 "show ip bgp flap-statistics prefix-list WORD",
7227 SHOW_STR
7228 IP_STR
7229 BGP_STR
7230 "Display flap statistics of routes\n"
7231 "Display routes conforming to the prefix-list\n"
7232 "IP prefix-list name\n")
7233{
7234 return bgp_show_prefix_list (vty, argv[0], AFI_IP, SAFI_UNICAST,
7235 bgp_show_type_flap_prefix_list);
7236}
7237
7238DEFUN (show_ip_bgp_ipv4_prefix_list,
7239 show_ip_bgp_ipv4_prefix_list_cmd,
7240 "show ip bgp ipv4 (unicast|multicast) prefix-list WORD",
7241 SHOW_STR
7242 IP_STR
7243 BGP_STR
7244 "Address family\n"
7245 "Address Family modifier\n"
7246 "Address Family modifier\n"
7247 "Display routes conforming to the prefix-list\n"
7248 "IP prefix-list name\n")
7249{
7250 if (strncmp (argv[0], "m", 1) == 0)
7251 return bgp_show_prefix_list (vty, argv[1], AFI_IP, SAFI_MULTICAST,
7252 bgp_show_type_prefix_list);
7253
7254 return bgp_show_prefix_list (vty, argv[1], AFI_IP, SAFI_UNICAST,
7255 bgp_show_type_prefix_list);
7256}
7257
7258#ifdef HAVE_IPV6
7259DEFUN (show_bgp_prefix_list,
7260 show_bgp_prefix_list_cmd,
7261 "show bgp prefix-list WORD",
7262 SHOW_STR
7263 BGP_STR
7264 "Display routes conforming to the prefix-list\n"
7265 "IPv6 prefix-list name\n")
7266{
7267 return bgp_show_prefix_list (vty, argv[0], AFI_IP6, SAFI_UNICAST,
7268 bgp_show_type_prefix_list);
7269}
7270
7271ALIAS (show_bgp_prefix_list,
7272 show_bgp_ipv6_prefix_list_cmd,
7273 "show bgp ipv6 prefix-list WORD",
7274 SHOW_STR
7275 BGP_STR
7276 "Address family\n"
7277 "Display routes conforming to the prefix-list\n"
7278 "IPv6 prefix-list name\n")
7279
7280/* old command */
7281DEFUN (show_ipv6_bgp_prefix_list,
7282 show_ipv6_bgp_prefix_list_cmd,
7283 "show ipv6 bgp prefix-list WORD",
7284 SHOW_STR
7285 IPV6_STR
7286 BGP_STR
7287 "Display routes matching the prefix-list\n"
7288 "IPv6 prefix-list name\n")
7289{
7290 return bgp_show_prefix_list (vty, argv[0], AFI_IP6, SAFI_UNICAST,
7291 bgp_show_type_prefix_list);
7292}
7293
7294/* old command */
7295DEFUN (show_ipv6_mbgp_prefix_list,
7296 show_ipv6_mbgp_prefix_list_cmd,
7297 "show ipv6 mbgp prefix-list WORD",
7298 SHOW_STR
7299 IPV6_STR
7300 MBGP_STR
7301 "Display routes matching the prefix-list\n"
7302 "IPv6 prefix-list name\n")
7303{
7304 return bgp_show_prefix_list (vty, argv[0], AFI_IP6, SAFI_MULTICAST,
7305 bgp_show_type_prefix_list);
7306}
7307#endif /* HAVE_IPV6 */
7308\f
94f2b392 7309static int
fd79ac91 7310bgp_show_filter_list (struct vty *vty, const char *filter, afi_t afi,
718e3744 7311 safi_t safi, enum bgp_show_type type)
7312{
7313 struct as_list *as_list;
7314
7315 as_list = as_list_lookup (filter);
7316 if (as_list == NULL)
7317 {
7318 vty_out (vty, "%% %s is not a valid AS-path access-list name%s", filter, VTY_NEWLINE);
7319 return CMD_WARNING;
7320 }
7321
5a646650 7322 return bgp_show (vty, NULL, afi, safi, type, as_list);
718e3744 7323}
7324
7325DEFUN (show_ip_bgp_filter_list,
7326 show_ip_bgp_filter_list_cmd,
7327 "show ip bgp filter-list WORD",
7328 SHOW_STR
7329 IP_STR
7330 BGP_STR
7331 "Display routes conforming to the filter-list\n"
7332 "Regular expression access list name\n")
7333{
7334 return bgp_show_filter_list (vty, argv[0], AFI_IP, SAFI_UNICAST,
7335 bgp_show_type_filter_list);
7336}
7337
7338DEFUN (show_ip_bgp_flap_filter_list,
7339 show_ip_bgp_flap_filter_list_cmd,
7340 "show ip bgp flap-statistics filter-list WORD",
7341 SHOW_STR
7342 IP_STR
7343 BGP_STR
7344 "Display flap statistics of routes\n"
7345 "Display routes conforming to the filter-list\n"
7346 "Regular expression access list name\n")
7347{
7348 return bgp_show_filter_list (vty, argv[0], AFI_IP, SAFI_UNICAST,
7349 bgp_show_type_flap_filter_list);
7350}
7351
7352DEFUN (show_ip_bgp_ipv4_filter_list,
7353 show_ip_bgp_ipv4_filter_list_cmd,
7354 "show ip bgp ipv4 (unicast|multicast) filter-list WORD",
7355 SHOW_STR
7356 IP_STR
7357 BGP_STR
7358 "Address family\n"
7359 "Address Family modifier\n"
7360 "Address Family modifier\n"
7361 "Display routes conforming to the filter-list\n"
7362 "Regular expression access list name\n")
7363{
7364 if (strncmp (argv[0], "m", 1) == 0)
7365 return bgp_show_filter_list (vty, argv[1], AFI_IP, SAFI_MULTICAST,
7366 bgp_show_type_filter_list);
7367
7368 return bgp_show_filter_list (vty, argv[1], AFI_IP, SAFI_UNICAST,
7369 bgp_show_type_filter_list);
7370}
7371
7372#ifdef HAVE_IPV6
7373DEFUN (show_bgp_filter_list,
7374 show_bgp_filter_list_cmd,
7375 "show bgp filter-list WORD",
7376 SHOW_STR
7377 BGP_STR
7378 "Display routes conforming to the filter-list\n"
7379 "Regular expression access list name\n")
7380{
7381 return bgp_show_filter_list (vty, argv[0], AFI_IP6, SAFI_UNICAST,
7382 bgp_show_type_filter_list);
7383}
7384
7385ALIAS (show_bgp_filter_list,
7386 show_bgp_ipv6_filter_list_cmd,
7387 "show bgp ipv6 filter-list WORD",
7388 SHOW_STR
7389 BGP_STR
7390 "Address family\n"
7391 "Display routes conforming to the filter-list\n"
7392 "Regular expression access list name\n")
7393
7394/* old command */
7395DEFUN (show_ipv6_bgp_filter_list,
7396 show_ipv6_bgp_filter_list_cmd,
7397 "show ipv6 bgp filter-list WORD",
7398 SHOW_STR
7399 IPV6_STR
7400 BGP_STR
7401 "Display routes conforming to the filter-list\n"
7402 "Regular expression access list name\n")
7403{
7404 return bgp_show_filter_list (vty, argv[0], AFI_IP6, SAFI_UNICAST,
7405 bgp_show_type_filter_list);
7406}
7407
7408/* old command */
7409DEFUN (show_ipv6_mbgp_filter_list,
7410 show_ipv6_mbgp_filter_list_cmd,
7411 "show ipv6 mbgp filter-list WORD",
7412 SHOW_STR
7413 IPV6_STR
7414 MBGP_STR
7415 "Display routes conforming to the filter-list\n"
7416 "Regular expression access list name\n")
7417{
7418 return bgp_show_filter_list (vty, argv[0], AFI_IP6, SAFI_MULTICAST,
7419 bgp_show_type_filter_list);
7420}
7421#endif /* HAVE_IPV6 */
7422\f
94f2b392 7423static int
fd79ac91 7424bgp_show_route_map (struct vty *vty, const char *rmap_str, afi_t afi,
718e3744 7425 safi_t safi, enum bgp_show_type type)
7426{
7427 struct route_map *rmap;
7428
7429 rmap = route_map_lookup_by_name (rmap_str);
7430 if (! rmap)
7431 {
7432 vty_out (vty, "%% %s is not a valid route-map name%s",
7433 rmap_str, VTY_NEWLINE);
7434 return CMD_WARNING;
7435 }
7436
5a646650 7437 return bgp_show (vty, NULL, afi, safi, type, rmap);
718e3744 7438}
7439
7440DEFUN (show_ip_bgp_route_map,
7441 show_ip_bgp_route_map_cmd,
7442 "show ip bgp route-map WORD",
7443 SHOW_STR
7444 IP_STR
7445 BGP_STR
7446 "Display routes matching the route-map\n"
7447 "A route-map to match on\n")
7448{
7449 return bgp_show_route_map (vty, argv[0], AFI_IP, SAFI_UNICAST,
7450 bgp_show_type_route_map);
7451}
7452
7453DEFUN (show_ip_bgp_flap_route_map,
7454 show_ip_bgp_flap_route_map_cmd,
7455 "show ip bgp flap-statistics route-map WORD",
7456 SHOW_STR
7457 IP_STR
7458 BGP_STR
7459 "Display flap statistics of routes\n"
7460 "Display routes matching the route-map\n"
7461 "A route-map to match on\n")
7462{
7463 return bgp_show_route_map (vty, argv[0], AFI_IP, SAFI_UNICAST,
7464 bgp_show_type_flap_route_map);
7465}
7466
7467DEFUN (show_ip_bgp_ipv4_route_map,
7468 show_ip_bgp_ipv4_route_map_cmd,
7469 "show ip bgp ipv4 (unicast|multicast) route-map WORD",
7470 SHOW_STR
7471 IP_STR
7472 BGP_STR
7473 "Address family\n"
7474 "Address Family modifier\n"
7475 "Address Family modifier\n"
7476 "Display routes matching the route-map\n"
7477 "A route-map to match on\n")
7478{
7479 if (strncmp (argv[0], "m", 1) == 0)
7480 return bgp_show_route_map (vty, argv[1], AFI_IP, SAFI_MULTICAST,
7481 bgp_show_type_route_map);
7482
7483 return bgp_show_route_map (vty, argv[1], AFI_IP, SAFI_UNICAST,
7484 bgp_show_type_route_map);
7485}
7486
7487DEFUN (show_bgp_route_map,
7488 show_bgp_route_map_cmd,
7489 "show bgp route-map WORD",
7490 SHOW_STR
7491 BGP_STR
7492 "Display routes matching the route-map\n"
7493 "A route-map to match on\n")
7494{
7495 return bgp_show_route_map (vty, argv[0], AFI_IP6, SAFI_UNICAST,
7496 bgp_show_type_route_map);
7497}
7498
7499ALIAS (show_bgp_route_map,
7500 show_bgp_ipv6_route_map_cmd,
7501 "show bgp ipv6 route-map WORD",
7502 SHOW_STR
7503 BGP_STR
7504 "Address family\n"
7505 "Display routes matching the route-map\n"
7506 "A route-map to match on\n")
7507\f
7508DEFUN (show_ip_bgp_cidr_only,
7509 show_ip_bgp_cidr_only_cmd,
7510 "show ip bgp cidr-only",
7511 SHOW_STR
7512 IP_STR
7513 BGP_STR
7514 "Display only routes with non-natural netmasks\n")
7515{
7516 return bgp_show (vty, NULL, AFI_IP, SAFI_UNICAST,
5a646650 7517 bgp_show_type_cidr_only, NULL);
718e3744 7518}
7519
7520DEFUN (show_ip_bgp_flap_cidr_only,
7521 show_ip_bgp_flap_cidr_only_cmd,
7522 "show ip bgp flap-statistics cidr-only",
7523 SHOW_STR
7524 IP_STR
7525 BGP_STR
7526 "Display flap statistics of routes\n"
7527 "Display only routes with non-natural netmasks\n")
7528{
7529 return bgp_show (vty, NULL, AFI_IP, SAFI_UNICAST,
5a646650 7530 bgp_show_type_flap_cidr_only, NULL);
718e3744 7531}
7532
7533DEFUN (show_ip_bgp_ipv4_cidr_only,
7534 show_ip_bgp_ipv4_cidr_only_cmd,
7535 "show ip bgp ipv4 (unicast|multicast) cidr-only",
7536 SHOW_STR
7537 IP_STR
7538 BGP_STR
7539 "Address family\n"
7540 "Address Family modifier\n"
7541 "Address Family modifier\n"
7542 "Display only routes with non-natural netmasks\n")
7543{
7544 if (strncmp (argv[0], "m", 1) == 0)
7545 return bgp_show (vty, NULL, AFI_IP, SAFI_MULTICAST,
5a646650 7546 bgp_show_type_cidr_only, NULL);
718e3744 7547
7548 return bgp_show (vty, NULL, AFI_IP, SAFI_UNICAST,
5a646650 7549 bgp_show_type_cidr_only, NULL);
718e3744 7550}
7551\f
7552DEFUN (show_ip_bgp_community_all,
7553 show_ip_bgp_community_all_cmd,
7554 "show ip bgp community",
7555 SHOW_STR
7556 IP_STR
7557 BGP_STR
7558 "Display routes matching the communities\n")
7559{
7560 return bgp_show (vty, NULL, AFI_IP, SAFI_UNICAST,
5a646650 7561 bgp_show_type_community_all, NULL);
718e3744 7562}
7563
7564DEFUN (show_ip_bgp_ipv4_community_all,
7565 show_ip_bgp_ipv4_community_all_cmd,
7566 "show ip bgp ipv4 (unicast|multicast) community",
7567 SHOW_STR
7568 IP_STR
7569 BGP_STR
7570 "Address family\n"
7571 "Address Family modifier\n"
7572 "Address Family modifier\n"
7573 "Display routes matching the communities\n")
7574{
7575 if (strncmp (argv[0], "m", 1) == 0)
7576 return bgp_show (vty, NULL, AFI_IP, SAFI_MULTICAST,
5a646650 7577 bgp_show_type_community_all, NULL);
718e3744 7578
7579 return bgp_show (vty, NULL, AFI_IP, SAFI_UNICAST,
5a646650 7580 bgp_show_type_community_all, NULL);
718e3744 7581}
7582
7583#ifdef HAVE_IPV6
7584DEFUN (show_bgp_community_all,
7585 show_bgp_community_all_cmd,
7586 "show bgp community",
7587 SHOW_STR
7588 BGP_STR
7589 "Display routes matching the communities\n")
7590{
7591 return bgp_show (vty, NULL, AFI_IP6, SAFI_UNICAST,
5a646650 7592 bgp_show_type_community_all, NULL);
718e3744 7593}
7594
7595ALIAS (show_bgp_community_all,
7596 show_bgp_ipv6_community_all_cmd,
7597 "show bgp ipv6 community",
7598 SHOW_STR
7599 BGP_STR
7600 "Address family\n"
7601 "Display routes matching the communities\n")
7602
7603/* old command */
7604DEFUN (show_ipv6_bgp_community_all,
7605 show_ipv6_bgp_community_all_cmd,
7606 "show ipv6 bgp community",
7607 SHOW_STR
7608 IPV6_STR
7609 BGP_STR
7610 "Display routes matching the communities\n")
7611{
7612 return bgp_show (vty, NULL, AFI_IP6, SAFI_UNICAST,
5a646650 7613 bgp_show_type_community_all, NULL);
718e3744 7614}
7615
7616/* old command */
7617DEFUN (show_ipv6_mbgp_community_all,
7618 show_ipv6_mbgp_community_all_cmd,
7619 "show ipv6 mbgp community",
7620 SHOW_STR
7621 IPV6_STR
7622 MBGP_STR
7623 "Display routes matching the communities\n")
7624{
7625 return bgp_show (vty, NULL, AFI_IP6, SAFI_MULTICAST,
5a646650 7626 bgp_show_type_community_all, NULL);
718e3744 7627}
7628#endif /* HAVE_IPV6 */
7629\f
94f2b392 7630static int
fd79ac91 7631bgp_show_community (struct vty *vty, int argc, const char **argv, int exact,
4c9641ba 7632 afi_t afi, safi_t safi)
718e3744 7633{
7634 struct community *com;
7635 struct buffer *b;
7636 int i;
7637 char *str;
7638 int first = 0;
7639
7640 b = buffer_new (1024);
7641 for (i = 0; i < argc; i++)
7642 {
7643 if (first)
7644 buffer_putc (b, ' ');
7645 else
7646 {
7647 if ((strcmp (argv[i], "unicast") == 0) || (strcmp (argv[i], "multicast") == 0))
7648 continue;
7649 first = 1;
7650 }
7651
7652 buffer_putstr (b, argv[i]);
7653 }
7654 buffer_putc (b, '\0');
7655
7656 str = buffer_getstr (b);
7657 buffer_free (b);
7658
7659 com = community_str2com (str);
3b8b1855 7660 XFREE (MTYPE_TMP, str);
718e3744 7661 if (! com)
7662 {
7663 vty_out (vty, "%% Community malformed: %s", VTY_NEWLINE);
7664 return CMD_WARNING;
7665 }
7666
5a646650 7667 return bgp_show (vty, NULL, afi, safi,
7668 (exact ? bgp_show_type_community_exact :
7669 bgp_show_type_community), com);
718e3744 7670}
7671
7672DEFUN (show_ip_bgp_community,
7673 show_ip_bgp_community_cmd,
7674 "show ip bgp community (AA:NN|local-AS|no-advertise|no-export)",
7675 SHOW_STR
7676 IP_STR
7677 BGP_STR
7678 "Display routes matching the communities\n"
7679 "community number\n"
7680 "Do not send outside local AS (well-known community)\n"
7681 "Do not advertise to any peer (well-known community)\n"
7682 "Do not export to next AS (well-known community)\n")
7683{
7684 return bgp_show_community (vty, argc, argv, 0, AFI_IP, SAFI_UNICAST);
7685}
7686
7687ALIAS (show_ip_bgp_community,
7688 show_ip_bgp_community2_cmd,
7689 "show ip bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
7690 SHOW_STR
7691 IP_STR
7692 BGP_STR
7693 "Display routes matching the communities\n"
7694 "community number\n"
7695 "Do not send outside local AS (well-known community)\n"
7696 "Do not advertise to any peer (well-known community)\n"
7697 "Do not export to next AS (well-known community)\n"
7698 "community number\n"
7699 "Do not send outside local AS (well-known community)\n"
7700 "Do not advertise to any peer (well-known community)\n"
7701 "Do not export to next AS (well-known community)\n")
7702
7703ALIAS (show_ip_bgp_community,
7704 show_ip_bgp_community3_cmd,
7705 "show ip bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
7706 SHOW_STR
7707 IP_STR
7708 BGP_STR
7709 "Display routes matching the communities\n"
7710 "community number\n"
7711 "Do not send outside local AS (well-known community)\n"
7712 "Do not advertise to any peer (well-known community)\n"
7713 "Do not export to next AS (well-known community)\n"
7714 "community number\n"
7715 "Do not send outside local AS (well-known community)\n"
7716 "Do not advertise to any peer (well-known community)\n"
7717 "Do not export to next AS (well-known community)\n"
7718 "community number\n"
7719 "Do not send outside local AS (well-known community)\n"
7720 "Do not advertise to any peer (well-known community)\n"
7721 "Do not export to next AS (well-known community)\n")
7722
7723ALIAS (show_ip_bgp_community,
7724 show_ip_bgp_community4_cmd,
7725 "show ip bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
7726 SHOW_STR
7727 IP_STR
7728 BGP_STR
7729 "Display routes matching the communities\n"
7730 "community number\n"
7731 "Do not send outside local AS (well-known community)\n"
7732 "Do not advertise to any peer (well-known community)\n"
7733 "Do not export to next AS (well-known community)\n"
7734 "community number\n"
7735 "Do not send outside local AS (well-known community)\n"
7736 "Do not advertise to any peer (well-known community)\n"
7737 "Do not export to next AS (well-known community)\n"
7738 "community number\n"
7739 "Do not send outside local AS (well-known community)\n"
7740 "Do not advertise to any peer (well-known community)\n"
7741 "Do not export to next AS (well-known community)\n"
7742 "community number\n"
7743 "Do not send outside local AS (well-known community)\n"
7744 "Do not advertise to any peer (well-known community)\n"
7745 "Do not export to next AS (well-known community)\n")
7746
7747DEFUN (show_ip_bgp_ipv4_community,
7748 show_ip_bgp_ipv4_community_cmd,
7749 "show ip bgp ipv4 (unicast|multicast) community (AA:NN|local-AS|no-advertise|no-export)",
7750 SHOW_STR
7751 IP_STR
7752 BGP_STR
7753 "Address family\n"
7754 "Address Family modifier\n"
7755 "Address Family modifier\n"
7756 "Display routes matching the communities\n"
7757 "community number\n"
7758 "Do not send outside local AS (well-known community)\n"
7759 "Do not advertise to any peer (well-known community)\n"
7760 "Do not export to next AS (well-known community)\n")
7761{
7762 if (strncmp (argv[0], "m", 1) == 0)
7763 return bgp_show_community (vty, argc, argv, 0, AFI_IP, SAFI_MULTICAST);
7764
7765 return bgp_show_community (vty, argc, argv, 0, AFI_IP, SAFI_UNICAST);
7766}
7767
7768ALIAS (show_ip_bgp_ipv4_community,
7769 show_ip_bgp_ipv4_community2_cmd,
7770 "show ip bgp ipv4 (unicast|multicast) community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
7771 SHOW_STR
7772 IP_STR
7773 BGP_STR
7774 "Address family\n"
7775 "Address Family modifier\n"
7776 "Address Family modifier\n"
7777 "Display routes matching the communities\n"
7778 "community number\n"
7779 "Do not send outside local AS (well-known community)\n"
7780 "Do not advertise to any peer (well-known community)\n"
7781 "Do not export to next AS (well-known community)\n"
7782 "community number\n"
7783 "Do not send outside local AS (well-known community)\n"
7784 "Do not advertise to any peer (well-known community)\n"
7785 "Do not export to next AS (well-known community)\n")
7786
7787ALIAS (show_ip_bgp_ipv4_community,
7788 show_ip_bgp_ipv4_community3_cmd,
7789 "show ip bgp ipv4 (unicast|multicast) community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
7790 SHOW_STR
7791 IP_STR
7792 BGP_STR
7793 "Address family\n"
7794 "Address Family modifier\n"
7795 "Address Family modifier\n"
7796 "Display routes matching the communities\n"
7797 "community number\n"
7798 "Do not send outside local AS (well-known community)\n"
7799 "Do not advertise to any peer (well-known community)\n"
7800 "Do not export to next AS (well-known community)\n"
7801 "community number\n"
7802 "Do not send outside local AS (well-known community)\n"
7803 "Do not advertise to any peer (well-known community)\n"
7804 "Do not export to next AS (well-known community)\n"
7805 "community number\n"
7806 "Do not send outside local AS (well-known community)\n"
7807 "Do not advertise to any peer (well-known community)\n"
7808 "Do not export to next AS (well-known community)\n")
7809
7810ALIAS (show_ip_bgp_ipv4_community,
7811 show_ip_bgp_ipv4_community4_cmd,
7812 "show ip bgp ipv4 (unicast|multicast) community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
7813 SHOW_STR
7814 IP_STR
7815 BGP_STR
7816 "Address family\n"
7817 "Address Family modifier\n"
7818 "Address Family modifier\n"
7819 "Display routes matching the communities\n"
7820 "community number\n"
7821 "Do not send outside local AS (well-known community)\n"
7822 "Do not advertise to any peer (well-known community)\n"
7823 "Do not export to next AS (well-known community)\n"
7824 "community number\n"
7825 "Do not send outside local AS (well-known community)\n"
7826 "Do not advertise to any peer (well-known community)\n"
7827 "Do not export to next AS (well-known community)\n"
7828 "community number\n"
7829 "Do not send outside local AS (well-known community)\n"
7830 "Do not advertise to any peer (well-known community)\n"
7831 "Do not export to next AS (well-known community)\n"
7832 "community number\n"
7833 "Do not send outside local AS (well-known community)\n"
7834 "Do not advertise to any peer (well-known community)\n"
7835 "Do not export to next AS (well-known community)\n")
7836
7837DEFUN (show_ip_bgp_community_exact,
7838 show_ip_bgp_community_exact_cmd,
7839 "show ip bgp community (AA:NN|local-AS|no-advertise|no-export) exact-match",
7840 SHOW_STR
7841 IP_STR
7842 BGP_STR
7843 "Display routes matching the communities\n"
7844 "community number\n"
7845 "Do not send outside local AS (well-known community)\n"
7846 "Do not advertise to any peer (well-known community)\n"
7847 "Do not export to next AS (well-known community)\n"
7848 "Exact match of the communities")
7849{
7850 return bgp_show_community (vty, argc, argv, 1, AFI_IP, SAFI_UNICAST);
7851}
7852
7853ALIAS (show_ip_bgp_community_exact,
7854 show_ip_bgp_community2_exact_cmd,
7855 "show ip bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
7856 SHOW_STR
7857 IP_STR
7858 BGP_STR
7859 "Display routes matching the communities\n"
7860 "community number\n"
7861 "Do not send outside local AS (well-known community)\n"
7862 "Do not advertise to any peer (well-known community)\n"
7863 "Do not export to next AS (well-known community)\n"
7864 "community number\n"
7865 "Do not send outside local AS (well-known community)\n"
7866 "Do not advertise to any peer (well-known community)\n"
7867 "Do not export to next AS (well-known community)\n"
7868 "Exact match of the communities")
7869
7870ALIAS (show_ip_bgp_community_exact,
7871 show_ip_bgp_community3_exact_cmd,
7872 "show ip bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
7873 SHOW_STR
7874 IP_STR
7875 BGP_STR
7876 "Display routes matching the communities\n"
7877 "community number\n"
7878 "Do not send outside local AS (well-known community)\n"
7879 "Do not advertise to any peer (well-known community)\n"
7880 "Do not export to next AS (well-known community)\n"
7881 "community number\n"
7882 "Do not send outside local AS (well-known community)\n"
7883 "Do not advertise to any peer (well-known community)\n"
7884 "Do not export to next AS (well-known community)\n"
7885 "community number\n"
7886 "Do not send outside local AS (well-known community)\n"
7887 "Do not advertise to any peer (well-known community)\n"
7888 "Do not export to next AS (well-known community)\n"
7889 "Exact match of the communities")
7890
7891ALIAS (show_ip_bgp_community_exact,
7892 show_ip_bgp_community4_exact_cmd,
7893 "show ip bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
7894 SHOW_STR
7895 IP_STR
7896 BGP_STR
7897 "Display routes matching the communities\n"
7898 "community number\n"
7899 "Do not send outside local AS (well-known community)\n"
7900 "Do not advertise to any peer (well-known community)\n"
7901 "Do not export to next AS (well-known community)\n"
7902 "community number\n"
7903 "Do not send outside local AS (well-known community)\n"
7904 "Do not advertise to any peer (well-known community)\n"
7905 "Do not export to next AS (well-known community)\n"
7906 "community number\n"
7907 "Do not send outside local AS (well-known community)\n"
7908 "Do not advertise to any peer (well-known community)\n"
7909 "Do not export to next AS (well-known community)\n"
7910 "community number\n"
7911 "Do not send outside local AS (well-known community)\n"
7912 "Do not advertise to any peer (well-known community)\n"
7913 "Do not export to next AS (well-known community)\n"
7914 "Exact match of the communities")
7915
7916DEFUN (show_ip_bgp_ipv4_community_exact,
7917 show_ip_bgp_ipv4_community_exact_cmd,
7918 "show ip bgp ipv4 (unicast|multicast) community (AA:NN|local-AS|no-advertise|no-export) exact-match",
7919 SHOW_STR
7920 IP_STR
7921 BGP_STR
7922 "Address family\n"
7923 "Address Family modifier\n"
7924 "Address Family modifier\n"
7925 "Display routes matching the communities\n"
7926 "community number\n"
7927 "Do not send outside local AS (well-known community)\n"
7928 "Do not advertise to any peer (well-known community)\n"
7929 "Do not export to next AS (well-known community)\n"
7930 "Exact match of the communities")
7931{
7932 if (strncmp (argv[0], "m", 1) == 0)
7933 return bgp_show_community (vty, argc, argv, 1, AFI_IP, SAFI_MULTICAST);
7934
7935 return bgp_show_community (vty, argc, argv, 1, AFI_IP, SAFI_UNICAST);
7936}
7937
7938ALIAS (show_ip_bgp_ipv4_community_exact,
7939 show_ip_bgp_ipv4_community2_exact_cmd,
7940 "show ip bgp ipv4 (unicast|multicast) community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
7941 SHOW_STR
7942 IP_STR
7943 BGP_STR
7944 "Address family\n"
7945 "Address Family modifier\n"
7946 "Address Family modifier\n"
7947 "Display routes matching the communities\n"
7948 "community number\n"
7949 "Do not send outside local AS (well-known community)\n"
7950 "Do not advertise to any peer (well-known community)\n"
7951 "Do not export to next AS (well-known community)\n"
7952 "community number\n"
7953 "Do not send outside local AS (well-known community)\n"
7954 "Do not advertise to any peer (well-known community)\n"
7955 "Do not export to next AS (well-known community)\n"
7956 "Exact match of the communities")
7957
7958ALIAS (show_ip_bgp_ipv4_community_exact,
7959 show_ip_bgp_ipv4_community3_exact_cmd,
7960 "show ip bgp ipv4 (unicast|multicast) community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
7961 SHOW_STR
7962 IP_STR
7963 BGP_STR
7964 "Address family\n"
7965 "Address Family modifier\n"
7966 "Address Family modifier\n"
7967 "Display routes matching the communities\n"
7968 "community number\n"
7969 "Do not send outside local AS (well-known community)\n"
7970 "Do not advertise to any peer (well-known community)\n"
7971 "Do not export to next AS (well-known community)\n"
7972 "community number\n"
7973 "Do not send outside local AS (well-known community)\n"
7974 "Do not advertise to any peer (well-known community)\n"
7975 "Do not export to next AS (well-known community)\n"
7976 "community number\n"
7977 "Do not send outside local AS (well-known community)\n"
7978 "Do not advertise to any peer (well-known community)\n"
7979 "Do not export to next AS (well-known community)\n"
7980 "Exact match of the communities")
7981
7982ALIAS (show_ip_bgp_ipv4_community_exact,
7983 show_ip_bgp_ipv4_community4_exact_cmd,
7984 "show ip bgp ipv4 (unicast|multicast) community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
7985 SHOW_STR
7986 IP_STR
7987 BGP_STR
7988 "Address family\n"
7989 "Address Family modifier\n"
7990 "Address Family modifier\n"
7991 "Display routes matching the communities\n"
7992 "community number\n"
7993 "Do not send outside local AS (well-known community)\n"
7994 "Do not advertise to any peer (well-known community)\n"
7995 "Do not export to next AS (well-known community)\n"
7996 "community number\n"
7997 "Do not send outside local AS (well-known community)\n"
7998 "Do not advertise to any peer (well-known community)\n"
7999 "Do not export to next AS (well-known community)\n"
8000 "community number\n"
8001 "Do not send outside local AS (well-known community)\n"
8002 "Do not advertise to any peer (well-known community)\n"
8003 "Do not export to next AS (well-known community)\n"
8004 "community number\n"
8005 "Do not send outside local AS (well-known community)\n"
8006 "Do not advertise to any peer (well-known community)\n"
8007 "Do not export to next AS (well-known community)\n"
8008 "Exact match of the communities")
8009
8010#ifdef HAVE_IPV6
8011DEFUN (show_bgp_community,
8012 show_bgp_community_cmd,
8013 "show bgp community (AA:NN|local-AS|no-advertise|no-export)",
8014 SHOW_STR
8015 BGP_STR
8016 "Display routes matching the communities\n"
8017 "community number\n"
8018 "Do not send outside local AS (well-known community)\n"
8019 "Do not advertise to any peer (well-known community)\n"
8020 "Do not export to next AS (well-known community)\n")
8021{
8022 return bgp_show_community (vty, argc, argv, 0, AFI_IP6, SAFI_UNICAST);
8023}
8024
8025ALIAS (show_bgp_community,
8026 show_bgp_ipv6_community_cmd,
8027 "show bgp ipv6 community (AA:NN|local-AS|no-advertise|no-export)",
8028 SHOW_STR
8029 BGP_STR
8030 "Address family\n"
8031 "Display routes matching the communities\n"
8032 "community number\n"
8033 "Do not send outside local AS (well-known community)\n"
8034 "Do not advertise to any peer (well-known community)\n"
8035 "Do not export to next AS (well-known community)\n")
8036
8037ALIAS (show_bgp_community,
8038 show_bgp_community2_cmd,
8039 "show bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
8040 SHOW_STR
8041 BGP_STR
8042 "Display routes matching the communities\n"
8043 "community number\n"
8044 "Do not send outside local AS (well-known community)\n"
8045 "Do not advertise to any peer (well-known community)\n"
8046 "Do not export to next AS (well-known community)\n"
8047 "community number\n"
8048 "Do not send outside local AS (well-known community)\n"
8049 "Do not advertise to any peer (well-known community)\n"
8050 "Do not export to next AS (well-known community)\n")
8051
8052ALIAS (show_bgp_community,
8053 show_bgp_ipv6_community2_cmd,
8054 "show bgp ipv6 community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
8055 SHOW_STR
8056 BGP_STR
8057 "Address family\n"
8058 "Display routes matching the communities\n"
8059 "community number\n"
8060 "Do not send outside local AS (well-known community)\n"
8061 "Do not advertise to any peer (well-known community)\n"
8062 "Do not export to next AS (well-known community)\n"
8063 "community number\n"
8064 "Do not send outside local AS (well-known community)\n"
8065 "Do not advertise to any peer (well-known community)\n"
8066 "Do not export to next AS (well-known community)\n")
8067
8068ALIAS (show_bgp_community,
8069 show_bgp_community3_cmd,
8070 "show bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
8071 SHOW_STR
8072 BGP_STR
8073 "Display routes matching the communities\n"
8074 "community number\n"
8075 "Do not send outside local AS (well-known community)\n"
8076 "Do not advertise to any peer (well-known community)\n"
8077 "Do not export to next AS (well-known community)\n"
8078 "community number\n"
8079 "Do not send outside local AS (well-known community)\n"
8080 "Do not advertise to any peer (well-known community)\n"
8081 "Do not export to next AS (well-known community)\n"
8082 "community number\n"
8083 "Do not send outside local AS (well-known community)\n"
8084 "Do not advertise to any peer (well-known community)\n"
8085 "Do not export to next AS (well-known community)\n")
8086
8087ALIAS (show_bgp_community,
8088 show_bgp_ipv6_community3_cmd,
8089 "show bgp ipv6 community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
8090 SHOW_STR
8091 BGP_STR
8092 "Address family\n"
8093 "Display routes matching the communities\n"
8094 "community number\n"
8095 "Do not send outside local AS (well-known community)\n"
8096 "Do not advertise to any peer (well-known community)\n"
8097 "Do not export to next AS (well-known community)\n"
8098 "community number\n"
8099 "Do not send outside local AS (well-known community)\n"
8100 "Do not advertise to any peer (well-known community)\n"
8101 "Do not export to next AS (well-known community)\n"
8102 "community number\n"
8103 "Do not send outside local AS (well-known community)\n"
8104 "Do not advertise to any peer (well-known community)\n"
8105 "Do not export to next AS (well-known community)\n")
8106
8107ALIAS (show_bgp_community,
8108 show_bgp_community4_cmd,
8109 "show bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
8110 SHOW_STR
8111 BGP_STR
8112 "Display routes matching the communities\n"
8113 "community number\n"
8114 "Do not send outside local AS (well-known community)\n"
8115 "Do not advertise to any peer (well-known community)\n"
8116 "Do not export to next AS (well-known community)\n"
8117 "community number\n"
8118 "Do not send outside local AS (well-known community)\n"
8119 "Do not advertise to any peer (well-known community)\n"
8120 "Do not export to next AS (well-known community)\n"
8121 "community number\n"
8122 "Do not send outside local AS (well-known community)\n"
8123 "Do not advertise to any peer (well-known community)\n"
8124 "Do not export to next AS (well-known community)\n"
8125 "community number\n"
8126 "Do not send outside local AS (well-known community)\n"
8127 "Do not advertise to any peer (well-known community)\n"
8128 "Do not export to next AS (well-known community)\n")
8129
8130ALIAS (show_bgp_community,
8131 show_bgp_ipv6_community4_cmd,
8132 "show bgp ipv6 community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
8133 SHOW_STR
8134 BGP_STR
8135 "Address family\n"
8136 "Display routes matching the communities\n"
8137 "community number\n"
8138 "Do not send outside local AS (well-known community)\n"
8139 "Do not advertise to any peer (well-known community)\n"
8140 "Do not export to next AS (well-known community)\n"
8141 "community number\n"
8142 "Do not send outside local AS (well-known community)\n"
8143 "Do not advertise to any peer (well-known community)\n"
8144 "Do not export to next AS (well-known community)\n"
8145 "community number\n"
8146 "Do not send outside local AS (well-known community)\n"
8147 "Do not advertise to any peer (well-known community)\n"
8148 "Do not export to next AS (well-known community)\n"
8149 "community number\n"
8150 "Do not send outside local AS (well-known community)\n"
8151 "Do not advertise to any peer (well-known community)\n"
8152 "Do not export to next AS (well-known community)\n")
8153
8154/* old command */
8155DEFUN (show_ipv6_bgp_community,
8156 show_ipv6_bgp_community_cmd,
8157 "show ipv6 bgp community (AA:NN|local-AS|no-advertise|no-export)",
8158 SHOW_STR
8159 IPV6_STR
8160 BGP_STR
8161 "Display routes matching the communities\n"
8162 "community number\n"
8163 "Do not send outside local AS (well-known community)\n"
8164 "Do not advertise to any peer (well-known community)\n"
8165 "Do not export to next AS (well-known community)\n")
8166{
8167 return bgp_show_community (vty, argc, argv, 0, AFI_IP6, SAFI_UNICAST);
8168}
8169
8170/* old command */
8171ALIAS (show_ipv6_bgp_community,
8172 show_ipv6_bgp_community2_cmd,
8173 "show ipv6 bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
8174 SHOW_STR
8175 IPV6_STR
8176 BGP_STR
8177 "Display routes matching the communities\n"
8178 "community number\n"
8179 "Do not send outside local AS (well-known community)\n"
8180 "Do not advertise to any peer (well-known community)\n"
8181 "Do not export to next AS (well-known community)\n"
8182 "community number\n"
8183 "Do not send outside local AS (well-known community)\n"
8184 "Do not advertise to any peer (well-known community)\n"
8185 "Do not export to next AS (well-known community)\n")
8186
8187/* old command */
8188ALIAS (show_ipv6_bgp_community,
8189 show_ipv6_bgp_community3_cmd,
8190 "show ipv6 bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
8191 SHOW_STR
8192 IPV6_STR
8193 BGP_STR
8194 "Display routes matching the communities\n"
8195 "community number\n"
8196 "Do not send outside local AS (well-known community)\n"
8197 "Do not advertise to any peer (well-known community)\n"
8198 "Do not export to next AS (well-known community)\n"
8199 "community number\n"
8200 "Do not send outside local AS (well-known community)\n"
8201 "Do not advertise to any peer (well-known community)\n"
8202 "Do not export to next AS (well-known community)\n"
8203 "community number\n"
8204 "Do not send outside local AS (well-known community)\n"
8205 "Do not advertise to any peer (well-known community)\n"
8206 "Do not export to next AS (well-known community)\n")
8207
8208/* old command */
8209ALIAS (show_ipv6_bgp_community,
8210 show_ipv6_bgp_community4_cmd,
8211 "show ipv6 bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
8212 SHOW_STR
8213 IPV6_STR
8214 BGP_STR
8215 "Display routes matching the communities\n"
8216 "community number\n"
8217 "Do not send outside local AS (well-known community)\n"
8218 "Do not advertise to any peer (well-known community)\n"
8219 "Do not export to next AS (well-known community)\n"
8220 "community number\n"
8221 "Do not send outside local AS (well-known community)\n"
8222 "Do not advertise to any peer (well-known community)\n"
8223 "Do not export to next AS (well-known community)\n"
8224 "community number\n"
8225 "Do not send outside local AS (well-known community)\n"
8226 "Do not advertise to any peer (well-known community)\n"
8227 "Do not export to next AS (well-known community)\n"
8228 "community number\n"
8229 "Do not send outside local AS (well-known community)\n"
8230 "Do not advertise to any peer (well-known community)\n"
8231 "Do not export to next AS (well-known community)\n")
8232
8233DEFUN (show_bgp_community_exact,
8234 show_bgp_community_exact_cmd,
8235 "show bgp community (AA:NN|local-AS|no-advertise|no-export) exact-match",
8236 SHOW_STR
8237 BGP_STR
8238 "Display routes matching the communities\n"
8239 "community number\n"
8240 "Do not send outside local AS (well-known community)\n"
8241 "Do not advertise to any peer (well-known community)\n"
8242 "Do not export to next AS (well-known community)\n"
8243 "Exact match of the communities")
8244{
8245 return bgp_show_community (vty, argc, argv, 1, AFI_IP6, SAFI_UNICAST);
8246}
8247
8248ALIAS (show_bgp_community_exact,
8249 show_bgp_ipv6_community_exact_cmd,
8250 "show bgp ipv6 community (AA:NN|local-AS|no-advertise|no-export) exact-match",
8251 SHOW_STR
8252 BGP_STR
8253 "Address family\n"
8254 "Display routes matching the communities\n"
8255 "community number\n"
8256 "Do not send outside local AS (well-known community)\n"
8257 "Do not advertise to any peer (well-known community)\n"
8258 "Do not export to next AS (well-known community)\n"
8259 "Exact match of the communities")
8260
8261ALIAS (show_bgp_community_exact,
8262 show_bgp_community2_exact_cmd,
8263 "show bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
8264 SHOW_STR
8265 BGP_STR
8266 "Display routes matching the communities\n"
8267 "community number\n"
8268 "Do not send outside local AS (well-known community)\n"
8269 "Do not advertise to any peer (well-known community)\n"
8270 "Do not export to next AS (well-known community)\n"
8271 "community number\n"
8272 "Do not send outside local AS (well-known community)\n"
8273 "Do not advertise to any peer (well-known community)\n"
8274 "Do not export to next AS (well-known community)\n"
8275 "Exact match of the communities")
8276
8277ALIAS (show_bgp_community_exact,
8278 show_bgp_ipv6_community2_exact_cmd,
8279 "show bgp ipv6 community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
8280 SHOW_STR
8281 BGP_STR
8282 "Address family\n"
8283 "Display routes matching the communities\n"
8284 "community number\n"
8285 "Do not send outside local AS (well-known community)\n"
8286 "Do not advertise to any peer (well-known community)\n"
8287 "Do not export to next AS (well-known community)\n"
8288 "community number\n"
8289 "Do not send outside local AS (well-known community)\n"
8290 "Do not advertise to any peer (well-known community)\n"
8291 "Do not export to next AS (well-known community)\n"
8292 "Exact match of the communities")
8293
8294ALIAS (show_bgp_community_exact,
8295 show_bgp_community3_exact_cmd,
8296 "show bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
8297 SHOW_STR
8298 BGP_STR
8299 "Display routes matching the communities\n"
8300 "community number\n"
8301 "Do not send outside local AS (well-known community)\n"
8302 "Do not advertise to any peer (well-known community)\n"
8303 "Do not export to next AS (well-known community)\n"
8304 "community number\n"
8305 "Do not send outside local AS (well-known community)\n"
8306 "Do not advertise to any peer (well-known community)\n"
8307 "Do not export to next AS (well-known community)\n"
8308 "community number\n"
8309 "Do not send outside local AS (well-known community)\n"
8310 "Do not advertise to any peer (well-known community)\n"
8311 "Do not export to next AS (well-known community)\n"
8312 "Exact match of the communities")
8313
8314ALIAS (show_bgp_community_exact,
8315 show_bgp_ipv6_community3_exact_cmd,
8316 "show bgp ipv6 community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
8317 SHOW_STR
8318 BGP_STR
8319 "Address family\n"
8320 "Display routes matching the communities\n"
8321 "community number\n"
8322 "Do not send outside local AS (well-known community)\n"
8323 "Do not advertise to any peer (well-known community)\n"
8324 "Do not export to next AS (well-known community)\n"
8325 "community number\n"
8326 "Do not send outside local AS (well-known community)\n"
8327 "Do not advertise to any peer (well-known community)\n"
8328 "Do not export to next AS (well-known community)\n"
8329 "community number\n"
8330 "Do not send outside local AS (well-known community)\n"
8331 "Do not advertise to any peer (well-known community)\n"
8332 "Do not export to next AS (well-known community)\n"
8333 "Exact match of the communities")
8334
8335ALIAS (show_bgp_community_exact,
8336 show_bgp_community4_exact_cmd,
8337 "show bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
8338 SHOW_STR
8339 BGP_STR
8340 "Display routes matching the communities\n"
8341 "community number\n"
8342 "Do not send outside local AS (well-known community)\n"
8343 "Do not advertise to any peer (well-known community)\n"
8344 "Do not export to next AS (well-known community)\n"
8345 "community number\n"
8346 "Do not send outside local AS (well-known community)\n"
8347 "Do not advertise to any peer (well-known community)\n"
8348 "Do not export to next AS (well-known community)\n"
8349 "community number\n"
8350 "Do not send outside local AS (well-known community)\n"
8351 "Do not advertise to any peer (well-known community)\n"
8352 "Do not export to next AS (well-known community)\n"
8353 "community number\n"
8354 "Do not send outside local AS (well-known community)\n"
8355 "Do not advertise to any peer (well-known community)\n"
8356 "Do not export to next AS (well-known community)\n"
8357 "Exact match of the communities")
8358
8359ALIAS (show_bgp_community_exact,
8360 show_bgp_ipv6_community4_exact_cmd,
8361 "show bgp ipv6 community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
8362 SHOW_STR
8363 BGP_STR
8364 "Address family\n"
8365 "Display routes matching the communities\n"
8366 "community number\n"
8367 "Do not send outside local AS (well-known community)\n"
8368 "Do not advertise to any peer (well-known community)\n"
8369 "Do not export to next AS (well-known community)\n"
8370 "community number\n"
8371 "Do not send outside local AS (well-known community)\n"
8372 "Do not advertise to any peer (well-known community)\n"
8373 "Do not export to next AS (well-known community)\n"
8374 "community number\n"
8375 "Do not send outside local AS (well-known community)\n"
8376 "Do not advertise to any peer (well-known community)\n"
8377 "Do not export to next AS (well-known community)\n"
8378 "community number\n"
8379 "Do not send outside local AS (well-known community)\n"
8380 "Do not advertise to any peer (well-known community)\n"
8381 "Do not export to next AS (well-known community)\n"
8382 "Exact match of the communities")
8383
8384/* old command */
8385DEFUN (show_ipv6_bgp_community_exact,
8386 show_ipv6_bgp_community_exact_cmd,
8387 "show ipv6 bgp community (AA:NN|local-AS|no-advertise|no-export) exact-match",
8388 SHOW_STR
8389 IPV6_STR
8390 BGP_STR
8391 "Display routes matching the communities\n"
8392 "community number\n"
8393 "Do not send outside local AS (well-known community)\n"
8394 "Do not advertise to any peer (well-known community)\n"
8395 "Do not export to next AS (well-known community)\n"
8396 "Exact match of the communities")
8397{
8398 return bgp_show_community (vty, argc, argv, 1, AFI_IP6, SAFI_UNICAST);
8399}
8400
8401/* old command */
8402ALIAS (show_ipv6_bgp_community_exact,
8403 show_ipv6_bgp_community2_exact_cmd,
8404 "show ipv6 bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
8405 SHOW_STR
8406 IPV6_STR
8407 BGP_STR
8408 "Display routes matching the communities\n"
8409 "community number\n"
8410 "Do not send outside local AS (well-known community)\n"
8411 "Do not advertise to any peer (well-known community)\n"
8412 "Do not export to next AS (well-known community)\n"
8413 "community number\n"
8414 "Do not send outside local AS (well-known community)\n"
8415 "Do not advertise to any peer (well-known community)\n"
8416 "Do not export to next AS (well-known community)\n"
8417 "Exact match of the communities")
8418
8419/* old command */
8420ALIAS (show_ipv6_bgp_community_exact,
8421 show_ipv6_bgp_community3_exact_cmd,
8422 "show ipv6 bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
8423 SHOW_STR
8424 IPV6_STR
8425 BGP_STR
8426 "Display routes matching the communities\n"
8427 "community number\n"
8428 "Do not send outside local AS (well-known community)\n"
8429 "Do not advertise to any peer (well-known community)\n"
8430 "Do not export to next AS (well-known community)\n"
8431 "community number\n"
8432 "Do not send outside local AS (well-known community)\n"
8433 "Do not advertise to any peer (well-known community)\n"
8434 "Do not export to next AS (well-known community)\n"
8435 "community number\n"
8436 "Do not send outside local AS (well-known community)\n"
8437 "Do not advertise to any peer (well-known community)\n"
8438 "Do not export to next AS (well-known community)\n"
8439 "Exact match of the communities")
8440
8441/* old command */
8442ALIAS (show_ipv6_bgp_community_exact,
8443 show_ipv6_bgp_community4_exact_cmd,
8444 "show ipv6 bgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
8445 SHOW_STR
8446 IPV6_STR
8447 BGP_STR
8448 "Display routes matching the communities\n"
8449 "community number\n"
8450 "Do not send outside local AS (well-known community)\n"
8451 "Do not advertise to any peer (well-known community)\n"
8452 "Do not export to next AS (well-known community)\n"
8453 "community number\n"
8454 "Do not send outside local AS (well-known community)\n"
8455 "Do not advertise to any peer (well-known community)\n"
8456 "Do not export to next AS (well-known community)\n"
8457 "community number\n"
8458 "Do not send outside local AS (well-known community)\n"
8459 "Do not advertise to any peer (well-known community)\n"
8460 "Do not export to next AS (well-known community)\n"
8461 "community number\n"
8462 "Do not send outside local AS (well-known community)\n"
8463 "Do not advertise to any peer (well-known community)\n"
8464 "Do not export to next AS (well-known community)\n"
8465 "Exact match of the communities")
8466
8467/* old command */
8468DEFUN (show_ipv6_mbgp_community,
8469 show_ipv6_mbgp_community_cmd,
8470 "show ipv6 mbgp community (AA:NN|local-AS|no-advertise|no-export)",
8471 SHOW_STR
8472 IPV6_STR
8473 MBGP_STR
8474 "Display routes matching the communities\n"
8475 "community number\n"
8476 "Do not send outside local AS (well-known community)\n"
8477 "Do not advertise to any peer (well-known community)\n"
8478 "Do not export to next AS (well-known community)\n")
8479{
8480 return bgp_show_community (vty, argc, argv, 0, AFI_IP6, SAFI_MULTICAST);
8481}
8482
8483/* old command */
8484ALIAS (show_ipv6_mbgp_community,
8485 show_ipv6_mbgp_community2_cmd,
8486 "show ipv6 mbgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
8487 SHOW_STR
8488 IPV6_STR
8489 MBGP_STR
8490 "Display routes matching the communities\n"
8491 "community number\n"
8492 "Do not send outside local AS (well-known community)\n"
8493 "Do not advertise to any peer (well-known community)\n"
8494 "Do not export to next AS (well-known community)\n"
8495 "community number\n"
8496 "Do not send outside local AS (well-known community)\n"
8497 "Do not advertise to any peer (well-known community)\n"
8498 "Do not export to next AS (well-known community)\n")
8499
8500/* old command */
8501ALIAS (show_ipv6_mbgp_community,
8502 show_ipv6_mbgp_community3_cmd,
8503 "show ipv6 mbgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
8504 SHOW_STR
8505 IPV6_STR
8506 MBGP_STR
8507 "Display routes matching the communities\n"
8508 "community number\n"
8509 "Do not send outside local AS (well-known community)\n"
8510 "Do not advertise to any peer (well-known community)\n"
8511 "Do not export to next AS (well-known community)\n"
8512 "community number\n"
8513 "Do not send outside local AS (well-known community)\n"
8514 "Do not advertise to any peer (well-known community)\n"
8515 "Do not export to next AS (well-known community)\n"
8516 "community number\n"
8517 "Do not send outside local AS (well-known community)\n"
8518 "Do not advertise to any peer (well-known community)\n"
8519 "Do not export to next AS (well-known community)\n")
8520
8521/* old command */
8522ALIAS (show_ipv6_mbgp_community,
8523 show_ipv6_mbgp_community4_cmd,
8524 "show ipv6 mbgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export)",
8525 SHOW_STR
8526 IPV6_STR
8527 MBGP_STR
8528 "Display routes matching the communities\n"
8529 "community number\n"
8530 "Do not send outside local AS (well-known community)\n"
8531 "Do not advertise to any peer (well-known community)\n"
8532 "Do not export to next AS (well-known community)\n"
8533 "community number\n"
8534 "Do not send outside local AS (well-known community)\n"
8535 "Do not advertise to any peer (well-known community)\n"
8536 "Do not export to next AS (well-known community)\n"
8537 "community number\n"
8538 "Do not send outside local AS (well-known community)\n"
8539 "Do not advertise to any peer (well-known community)\n"
8540 "Do not export to next AS (well-known community)\n"
8541 "community number\n"
8542 "Do not send outside local AS (well-known community)\n"
8543 "Do not advertise to any peer (well-known community)\n"
8544 "Do not export to next AS (well-known community)\n")
8545
8546/* old command */
8547DEFUN (show_ipv6_mbgp_community_exact,
8548 show_ipv6_mbgp_community_exact_cmd,
8549 "show ipv6 mbgp community (AA:NN|local-AS|no-advertise|no-export) exact-match",
8550 SHOW_STR
8551 IPV6_STR
8552 MBGP_STR
8553 "Display routes matching the communities\n"
8554 "community number\n"
8555 "Do not send outside local AS (well-known community)\n"
8556 "Do not advertise to any peer (well-known community)\n"
8557 "Do not export to next AS (well-known community)\n"
8558 "Exact match of the communities")
8559{
8560 return bgp_show_community (vty, argc, argv, 1, AFI_IP6, SAFI_MULTICAST);
8561}
8562
8563/* old command */
8564ALIAS (show_ipv6_mbgp_community_exact,
8565 show_ipv6_mbgp_community2_exact_cmd,
8566 "show ipv6 mbgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
8567 SHOW_STR
8568 IPV6_STR
8569 MBGP_STR
8570 "Display routes matching the communities\n"
8571 "community number\n"
8572 "Do not send outside local AS (well-known community)\n"
8573 "Do not advertise to any peer (well-known community)\n"
8574 "Do not export to next AS (well-known community)\n"
8575 "community number\n"
8576 "Do not send outside local AS (well-known community)\n"
8577 "Do not advertise to any peer (well-known community)\n"
8578 "Do not export to next AS (well-known community)\n"
8579 "Exact match of the communities")
8580
8581/* old command */
8582ALIAS (show_ipv6_mbgp_community_exact,
8583 show_ipv6_mbgp_community3_exact_cmd,
8584 "show ipv6 mbgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
8585 SHOW_STR
8586 IPV6_STR
8587 MBGP_STR
8588 "Display routes matching the communities\n"
8589 "community number\n"
8590 "Do not send outside local AS (well-known community)\n"
8591 "Do not advertise to any peer (well-known community)\n"
8592 "Do not export to next AS (well-known community)\n"
8593 "community number\n"
8594 "Do not send outside local AS (well-known community)\n"
8595 "Do not advertise to any peer (well-known community)\n"
8596 "Do not export to next AS (well-known community)\n"
8597 "community number\n"
8598 "Do not send outside local AS (well-known community)\n"
8599 "Do not advertise to any peer (well-known community)\n"
8600 "Do not export to next AS (well-known community)\n"
8601 "Exact match of the communities")
8602
8603/* old command */
8604ALIAS (show_ipv6_mbgp_community_exact,
8605 show_ipv6_mbgp_community4_exact_cmd,
8606 "show ipv6 mbgp community (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) (AA:NN|local-AS|no-advertise|no-export) exact-match",
8607 SHOW_STR
8608 IPV6_STR
8609 MBGP_STR
8610 "Display routes matching the communities\n"
8611 "community number\n"
8612 "Do not send outside local AS (well-known community)\n"
8613 "Do not advertise to any peer (well-known community)\n"
8614 "Do not export to next AS (well-known community)\n"
8615 "community number\n"
8616 "Do not send outside local AS (well-known community)\n"
8617 "Do not advertise to any peer (well-known community)\n"
8618 "Do not export to next AS (well-known community)\n"
8619 "community number\n"
8620 "Do not send outside local AS (well-known community)\n"
8621 "Do not advertise to any peer (well-known community)\n"
8622 "Do not export to next AS (well-known community)\n"
8623 "community number\n"
8624 "Do not send outside local AS (well-known community)\n"
8625 "Do not advertise to any peer (well-known community)\n"
8626 "Do not export to next AS (well-known community)\n"
8627 "Exact match of the communities")
8628#endif /* HAVE_IPV6 */
8629\f
94f2b392 8630static int
fd79ac91 8631bgp_show_community_list (struct vty *vty, const char *com, int exact,
4c9641ba 8632 afi_t afi, safi_t safi)
718e3744 8633{
8634 struct community_list *list;
8635
fee6e4e4 8636 list = community_list_lookup (bgp_clist, com, COMMUNITY_LIST_MASTER);
718e3744 8637 if (list == NULL)
8638 {
8639 vty_out (vty, "%% %s is not a valid community-list name%s", com,
8640 VTY_NEWLINE);
8641 return CMD_WARNING;
8642 }
8643
5a646650 8644 return bgp_show (vty, NULL, afi, safi,
8645 (exact ? bgp_show_type_community_list_exact :
8646 bgp_show_type_community_list), list);
718e3744 8647}
8648
8649DEFUN (show_ip_bgp_community_list,
8650 show_ip_bgp_community_list_cmd,
fee6e4e4 8651 "show ip bgp community-list (<1-500>|WORD)",
718e3744 8652 SHOW_STR
8653 IP_STR
8654 BGP_STR
8655 "Display routes matching the community-list\n"
fee6e4e4 8656 "community-list number\n"
718e3744 8657 "community-list name\n")
8658{
8659 return bgp_show_community_list (vty, argv[0], 0, AFI_IP, SAFI_UNICAST);
8660}
8661
8662DEFUN (show_ip_bgp_ipv4_community_list,
8663 show_ip_bgp_ipv4_community_list_cmd,
fee6e4e4 8664 "show ip bgp ipv4 (unicast|multicast) community-list (<1-500>|WORD)",
718e3744 8665 SHOW_STR
8666 IP_STR
8667 BGP_STR
8668 "Address family\n"
8669 "Address Family modifier\n"
8670 "Address Family modifier\n"
8671 "Display routes matching the community-list\n"
fee6e4e4 8672 "community-list number\n"
718e3744 8673 "community-list name\n")
8674{
8675 if (strncmp (argv[0], "m", 1) == 0)
8676 return bgp_show_community_list (vty, argv[1], 0, AFI_IP, SAFI_MULTICAST);
8677
8678 return bgp_show_community_list (vty, argv[1], 0, AFI_IP, SAFI_UNICAST);
8679}
8680
8681DEFUN (show_ip_bgp_community_list_exact,
8682 show_ip_bgp_community_list_exact_cmd,
fee6e4e4 8683 "show ip bgp community-list (<1-500>|WORD) exact-match",
718e3744 8684 SHOW_STR
8685 IP_STR
8686 BGP_STR
8687 "Display routes matching the community-list\n"
fee6e4e4 8688 "community-list number\n"
718e3744 8689 "community-list name\n"
8690 "Exact match of the communities\n")
8691{
8692 return bgp_show_community_list (vty, argv[0], 1, AFI_IP, SAFI_UNICAST);
8693}
8694
8695DEFUN (show_ip_bgp_ipv4_community_list_exact,
8696 show_ip_bgp_ipv4_community_list_exact_cmd,
fee6e4e4 8697 "show ip bgp ipv4 (unicast|multicast) community-list (<1-500>|WORD) exact-match",
718e3744 8698 SHOW_STR
8699 IP_STR
8700 BGP_STR
8701 "Address family\n"
8702 "Address Family modifier\n"
8703 "Address Family modifier\n"
8704 "Display routes matching the community-list\n"
fee6e4e4 8705 "community-list number\n"
718e3744 8706 "community-list name\n"
8707 "Exact match of the communities\n")
8708{
8709 if (strncmp (argv[0], "m", 1) == 0)
8710 return bgp_show_community_list (vty, argv[1], 1, AFI_IP, SAFI_MULTICAST);
8711
8712 return bgp_show_community_list (vty, argv[1], 1, AFI_IP, SAFI_UNICAST);
8713}
8714
8715#ifdef HAVE_IPV6
8716DEFUN (show_bgp_community_list,
8717 show_bgp_community_list_cmd,
fee6e4e4 8718 "show bgp community-list (<1-500>|WORD)",
718e3744 8719 SHOW_STR
8720 BGP_STR
8721 "Display routes matching the community-list\n"
fee6e4e4 8722 "community-list number\n"
718e3744 8723 "community-list name\n")
8724{
8725 return bgp_show_community_list (vty, argv[0], 0, AFI_IP6, SAFI_UNICAST);
8726}
8727
8728ALIAS (show_bgp_community_list,
8729 show_bgp_ipv6_community_list_cmd,
fee6e4e4 8730 "show bgp ipv6 community-list (<1-500>|WORD)",
718e3744 8731 SHOW_STR
8732 BGP_STR
8733 "Address family\n"
8734 "Display routes matching the community-list\n"
fee6e4e4 8735 "community-list number\n"
e8e1946e 8736 "community-list name\n")
718e3744 8737
8738/* old command */
8739DEFUN (show_ipv6_bgp_community_list,
8740 show_ipv6_bgp_community_list_cmd,
8741 "show ipv6 bgp community-list WORD",
8742 SHOW_STR
8743 IPV6_STR
8744 BGP_STR
8745 "Display routes matching the community-list\n"
8746 "community-list name\n")
8747{
8748 return bgp_show_community_list (vty, argv[0], 0, AFI_IP6, SAFI_UNICAST);
8749}
8750
8751/* old command */
8752DEFUN (show_ipv6_mbgp_community_list,
8753 show_ipv6_mbgp_community_list_cmd,
8754 "show ipv6 mbgp community-list WORD",
8755 SHOW_STR
8756 IPV6_STR
8757 MBGP_STR
8758 "Display routes matching the community-list\n"
8759 "community-list name\n")
8760{
8761 return bgp_show_community_list (vty, argv[0], 0, AFI_IP6, SAFI_MULTICAST);
8762}
8763
8764DEFUN (show_bgp_community_list_exact,
8765 show_bgp_community_list_exact_cmd,
fee6e4e4 8766 "show bgp community-list (<1-500>|WORD) exact-match",
718e3744 8767 SHOW_STR
8768 BGP_STR
8769 "Display routes matching the community-list\n"
fee6e4e4 8770 "community-list number\n"
718e3744 8771 "community-list name\n"
8772 "Exact match of the communities\n")
8773{
8774 return bgp_show_community_list (vty, argv[0], 1, AFI_IP6, SAFI_UNICAST);
8775}
8776
8777ALIAS (show_bgp_community_list_exact,
8778 show_bgp_ipv6_community_list_exact_cmd,
fee6e4e4 8779 "show bgp ipv6 community-list (<1-500>|WORD) exact-match",
718e3744 8780 SHOW_STR
8781 BGP_STR
8782 "Address family\n"
8783 "Display routes matching the community-list\n"
fee6e4e4 8784 "community-list number\n"
718e3744 8785 "community-list name\n"
8786 "Exact match of the communities\n")
8787
8788/* old command */
8789DEFUN (show_ipv6_bgp_community_list_exact,
8790 show_ipv6_bgp_community_list_exact_cmd,
8791 "show ipv6 bgp community-list WORD exact-match",
8792 SHOW_STR
8793 IPV6_STR
8794 BGP_STR
8795 "Display routes matching the community-list\n"
8796 "community-list name\n"
8797 "Exact match of the communities\n")
8798{
8799 return bgp_show_community_list (vty, argv[0], 1, AFI_IP6, SAFI_UNICAST);
8800}
8801
8802/* old command */
8803DEFUN (show_ipv6_mbgp_community_list_exact,
8804 show_ipv6_mbgp_community_list_exact_cmd,
8805 "show ipv6 mbgp community-list WORD exact-match",
8806 SHOW_STR
8807 IPV6_STR
8808 MBGP_STR
8809 "Display routes matching the community-list\n"
8810 "community-list name\n"
8811 "Exact match of the communities\n")
8812{
8813 return bgp_show_community_list (vty, argv[0], 1, AFI_IP6, SAFI_MULTICAST);
8814}
8815#endif /* HAVE_IPV6 */
8816\f
94f2b392 8817static int
fd79ac91 8818bgp_show_prefix_longer (struct vty *vty, const char *prefix, afi_t afi,
718e3744 8819 safi_t safi, enum bgp_show_type type)
8820{
8821 int ret;
8822 struct prefix *p;
8823
8824 p = prefix_new();
8825
8826 ret = str2prefix (prefix, p);
8827 if (! ret)
8828 {
8829 vty_out (vty, "%% Malformed Prefix%s", VTY_NEWLINE);
8830 return CMD_WARNING;
8831 }
8832
5a646650 8833 ret = bgp_show (vty, NULL, afi, safi, type, p);
8834 prefix_free(p);
8835 return ret;
718e3744 8836}
8837
8838DEFUN (show_ip_bgp_prefix_longer,
8839 show_ip_bgp_prefix_longer_cmd,
8840 "show ip bgp A.B.C.D/M longer-prefixes",
8841 SHOW_STR
8842 IP_STR
8843 BGP_STR
8844 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n"
8845 "Display route and more specific routes\n")
8846{
8847 return bgp_show_prefix_longer (vty, argv[0], AFI_IP, SAFI_UNICAST,
8848 bgp_show_type_prefix_longer);
8849}
8850
8851DEFUN (show_ip_bgp_flap_prefix_longer,
8852 show_ip_bgp_flap_prefix_longer_cmd,
8853 "show ip bgp flap-statistics A.B.C.D/M longer-prefixes",
8854 SHOW_STR
8855 IP_STR
8856 BGP_STR
8857 "Display flap statistics of routes\n"
8858 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n"
8859 "Display route and more specific routes\n")
8860{
8861 return bgp_show_prefix_longer (vty, argv[0], AFI_IP, SAFI_UNICAST,
8862 bgp_show_type_flap_prefix_longer);
8863}
8864
8865DEFUN (show_ip_bgp_ipv4_prefix_longer,
8866 show_ip_bgp_ipv4_prefix_longer_cmd,
8867 "show ip bgp ipv4 (unicast|multicast) A.B.C.D/M longer-prefixes",
8868 SHOW_STR
8869 IP_STR
8870 BGP_STR
8871 "Address family\n"
8872 "Address Family modifier\n"
8873 "Address Family modifier\n"
8874 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n"
8875 "Display route and more specific routes\n")
8876{
8877 if (strncmp (argv[0], "m", 1) == 0)
8878 return bgp_show_prefix_longer (vty, argv[1], AFI_IP, SAFI_MULTICAST,
8879 bgp_show_type_prefix_longer);
8880
8881 return bgp_show_prefix_longer (vty, argv[1], AFI_IP, SAFI_UNICAST,
8882 bgp_show_type_prefix_longer);
8883}
8884
8885DEFUN (show_ip_bgp_flap_address,
8886 show_ip_bgp_flap_address_cmd,
8887 "show ip bgp flap-statistics A.B.C.D",
8888 SHOW_STR
8889 IP_STR
8890 BGP_STR
8891 "Display flap statistics of routes\n"
8892 "Network in the BGP routing table to display\n")
8893{
8894 return bgp_show_prefix_longer (vty, argv[0], AFI_IP, SAFI_UNICAST,
8895 bgp_show_type_flap_address);
8896}
8897
8898DEFUN (show_ip_bgp_flap_prefix,
8899 show_ip_bgp_flap_prefix_cmd,
8900 "show ip bgp flap-statistics A.B.C.D/M",
8901 SHOW_STR
8902 IP_STR
8903 BGP_STR
8904 "Display flap statistics of routes\n"
8905 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n")
8906{
8907 return bgp_show_prefix_longer (vty, argv[0], AFI_IP, SAFI_UNICAST,
8908 bgp_show_type_flap_prefix);
8909}
8910#ifdef HAVE_IPV6
8911DEFUN (show_bgp_prefix_longer,
8912 show_bgp_prefix_longer_cmd,
8913 "show bgp X:X::X:X/M longer-prefixes",
8914 SHOW_STR
8915 BGP_STR
8916 "IPv6 prefix <network>/<length>\n"
8917 "Display route and more specific routes\n")
8918{
8919 return bgp_show_prefix_longer (vty, argv[0], AFI_IP6, SAFI_UNICAST,
8920 bgp_show_type_prefix_longer);
8921}
8922
8923ALIAS (show_bgp_prefix_longer,
8924 show_bgp_ipv6_prefix_longer_cmd,
8925 "show bgp ipv6 X:X::X:X/M longer-prefixes",
8926 SHOW_STR
8927 BGP_STR
8928 "Address family\n"
8929 "IPv6 prefix <network>/<length>\n"
8930 "Display route and more specific routes\n")
8931
8932/* old command */
8933DEFUN (show_ipv6_bgp_prefix_longer,
8934 show_ipv6_bgp_prefix_longer_cmd,
8935 "show ipv6 bgp X:X::X:X/M longer-prefixes",
8936 SHOW_STR
8937 IPV6_STR
8938 BGP_STR
8939 "IPv6 prefix <network>/<length>, e.g., 3ffe::/16\n"
8940 "Display route and more specific routes\n")
8941{
8942 return bgp_show_prefix_longer (vty, argv[0], AFI_IP6, SAFI_UNICAST,
8943 bgp_show_type_prefix_longer);
8944}
8945
8946/* old command */
8947DEFUN (show_ipv6_mbgp_prefix_longer,
8948 show_ipv6_mbgp_prefix_longer_cmd,
8949 "show ipv6 mbgp X:X::X:X/M longer-prefixes",
8950 SHOW_STR
8951 IPV6_STR
8952 MBGP_STR
8953 "IPv6 prefix <network>/<length>, e.g., 3ffe::/16\n"
8954 "Display route and more specific routes\n")
8955{
8956 return bgp_show_prefix_longer (vty, argv[0], AFI_IP6, SAFI_MULTICAST,
8957 bgp_show_type_prefix_longer);
8958}
8959#endif /* HAVE_IPV6 */
bb46e94f 8960
94f2b392 8961static struct peer *
fd79ac91 8962peer_lookup_in_view (struct vty *vty, const char *view_name,
8963 const char *ip_str)
bb46e94f 8964{
8965 int ret;
8966 struct bgp *bgp;
8967 struct peer *peer;
8968 union sockunion su;
8969
8970 /* BGP structure lookup. */
8971 if (view_name)
8972 {
8973 bgp = bgp_lookup_by_name (view_name);
8974 if (! bgp)
8975 {
8976 vty_out (vty, "Can't find BGP view %s%s", view_name, VTY_NEWLINE);
8977 return NULL;
8978 }
8979 }
5228ad27 8980 else
bb46e94f 8981 {
8982 bgp = bgp_get_default ();
8983 if (! bgp)
8984 {
8985 vty_out (vty, "No BGP process is configured%s", VTY_NEWLINE);
8986 return NULL;
8987 }
8988 }
8989
8990 /* Get peer sockunion. */
8991 ret = str2sockunion (ip_str, &su);
8992 if (ret < 0)
8993 {
8994 vty_out (vty, "Malformed address: %s%s", ip_str, VTY_NEWLINE);
8995 return NULL;
8996 }
8997
8998 /* Peer structure lookup. */
8999 peer = peer_lookup (bgp, &su);
9000 if (! peer)
9001 {
9002 vty_out (vty, "No such neighbor%s", VTY_NEWLINE);
9003 return NULL;
9004 }
9005
9006 return peer;
9007}
2815e61f
PJ
9008\f
9009enum bgp_stats
9010{
9011 BGP_STATS_MAXBITLEN = 0,
9012 BGP_STATS_RIB,
9013 BGP_STATS_PREFIXES,
9014 BGP_STATS_TOTPLEN,
9015 BGP_STATS_UNAGGREGATEABLE,
9016 BGP_STATS_MAX_AGGREGATEABLE,
9017 BGP_STATS_AGGREGATES,
9018 BGP_STATS_SPACE,
9019 BGP_STATS_ASPATH_COUNT,
9020 BGP_STATS_ASPATH_MAXHOPS,
9021 BGP_STATS_ASPATH_TOTHOPS,
9022 BGP_STATS_ASPATH_MAXSIZE,
9023 BGP_STATS_ASPATH_TOTSIZE,
9024 BGP_STATS_ASN_HIGHEST,
9025 BGP_STATS_MAX,
9026};
9027
9028static const char *table_stats_strs[] =
9029{
9030 [BGP_STATS_PREFIXES] = "Total Prefixes",
9031 [BGP_STATS_TOTPLEN] = "Average prefix length",
9032 [BGP_STATS_RIB] = "Total Advertisements",
9033 [BGP_STATS_UNAGGREGATEABLE] = "Unaggregateable prefixes",
9034 [BGP_STATS_MAX_AGGREGATEABLE] = "Maximum aggregateable prefixes",
9035 [BGP_STATS_AGGREGATES] = "BGP Aggregate advertisements",
9036 [BGP_STATS_SPACE] = "Address space advertised",
9037 [BGP_STATS_ASPATH_COUNT] = "Advertisements with paths",
9038 [BGP_STATS_ASPATH_MAXHOPS] = "Longest AS-Path (hops)",
9039 [BGP_STATS_ASPATH_MAXSIZE] = "Largest AS-Path (bytes)",
9040 [BGP_STATS_ASPATH_TOTHOPS] = "Average AS-Path length (hops)",
9041 [BGP_STATS_ASPATH_TOTSIZE] = "Average AS-Path size (bytes)",
9042 [BGP_STATS_ASN_HIGHEST] = "Highest public ASN",
9043 [BGP_STATS_MAX] = NULL,
9044};
9045
9046struct bgp_table_stats
9047{
9048 struct bgp_table *table;
9049 unsigned long long counts[BGP_STATS_MAX];
9050};
9051
9052#if 0
9053#define TALLY_SIGFIG 100000
9054static unsigned long
9055ravg_tally (unsigned long count, unsigned long oldavg, unsigned long newval)
9056{
9057 unsigned long newtot = (count-1) * oldavg + (newval * TALLY_SIGFIG);
9058 unsigned long res = (newtot * TALLY_SIGFIG) / count;
9059 unsigned long ret = newtot / count;
9060
9061 if ((res % TALLY_SIGFIG) > (TALLY_SIGFIG/2))
9062 return ret + 1;
9063 else
9064 return ret;
9065}
9066#endif
9067
9068static int
9069bgp_table_stats_walker (struct thread *t)
9070{
9071 struct bgp_node *rn;
9072 struct bgp_node *top;
9073 struct bgp_table_stats *ts = THREAD_ARG (t);
9074 unsigned int space = 0;
9075
53d9f67a
PJ
9076 if (!(top = bgp_table_top (ts->table)))
9077 return 0;
2815e61f
PJ
9078
9079 switch (top->p.family)
9080 {
9081 case AF_INET:
9082 space = IPV4_MAX_BITLEN;
9083 break;
9084 case AF_INET6:
9085 space = IPV6_MAX_BITLEN;
9086 break;
9087 }
9088
9089 ts->counts[BGP_STATS_MAXBITLEN] = space;
9090
9091 for (rn = top; rn; rn = bgp_route_next (rn))
9092 {
9093 struct bgp_info *ri;
9094 struct bgp_node *prn = rn->parent;
9095 unsigned int rinum = 0;
9096
9097 if (rn == top)
9098 continue;
9099
9100 if (!rn->info)
9101 continue;
9102
9103 ts->counts[BGP_STATS_PREFIXES]++;
9104 ts->counts[BGP_STATS_TOTPLEN] += rn->p.prefixlen;
9105
9106#if 0
9107 ts->counts[BGP_STATS_AVGPLEN]
9108 = ravg_tally (ts->counts[BGP_STATS_PREFIXES],
9109 ts->counts[BGP_STATS_AVGPLEN],
9110 rn->p.prefixlen);
9111#endif
9112
9113 /* check if the prefix is included by any other announcements */
9114 while (prn && !prn->info)
9115 prn = prn->parent;
9116
9117 if (prn == NULL || prn == top)
8383a9bd
PJ
9118 {
9119 ts->counts[BGP_STATS_UNAGGREGATEABLE]++;
9120 /* announced address space */
9121 if (space)
9122 ts->counts[BGP_STATS_SPACE] += 1 << (space - rn->p.prefixlen);
9123 }
2815e61f
PJ
9124 else if (prn->info)
9125 ts->counts[BGP_STATS_MAX_AGGREGATEABLE]++;
9126
2815e61f
PJ
9127 for (ri = rn->info; ri; ri = ri->next)
9128 {
9129 rinum++;
9130 ts->counts[BGP_STATS_RIB]++;
9131
9132 if (ri->attr &&
9133 (CHECK_FLAG (ri->attr->flag,
9134 ATTR_FLAG_BIT (BGP_ATTR_ATOMIC_AGGREGATE))))
9135 ts->counts[BGP_STATS_AGGREGATES]++;
9136
9137 /* as-path stats */
9138 if (ri->attr && ri->attr->aspath)
9139 {
9140 unsigned int hops = aspath_count_hops (ri->attr->aspath);
9141 unsigned int size = aspath_size (ri->attr->aspath);
9142 as_t highest = aspath_highest (ri->attr->aspath);
9143
9144 ts->counts[BGP_STATS_ASPATH_COUNT]++;
9145
9146 if (hops > ts->counts[BGP_STATS_ASPATH_MAXHOPS])
9147 ts->counts[BGP_STATS_ASPATH_MAXHOPS] = hops;
9148
9149 if (size > ts->counts[BGP_STATS_ASPATH_MAXSIZE])
9150 ts->counts[BGP_STATS_ASPATH_MAXSIZE] = size;
9151
9152 ts->counts[BGP_STATS_ASPATH_TOTHOPS] += hops;
9153 ts->counts[BGP_STATS_ASPATH_TOTSIZE] += size;
9154#if 0
9155 ts->counts[BGP_STATS_ASPATH_AVGHOPS]
9156 = ravg_tally (ts->counts[BGP_STATS_ASPATH_COUNT],
9157 ts->counts[BGP_STATS_ASPATH_AVGHOPS],
9158 hops);
9159 ts->counts[BGP_STATS_ASPATH_AVGSIZE]
9160 = ravg_tally (ts->counts[BGP_STATS_ASPATH_COUNT],
9161 ts->counts[BGP_STATS_ASPATH_AVGSIZE],
9162 size);
9163#endif
9164 if (highest > ts->counts[BGP_STATS_ASN_HIGHEST])
9165 ts->counts[BGP_STATS_ASN_HIGHEST] = highest;
9166 }
9167 }
9168 }
9169 return 0;
9170}
9171
9172static int
9173bgp_table_stats (struct vty *vty, struct bgp *bgp, afi_t afi, safi_t safi)
9174{
9175 struct bgp_table_stats ts;
9176 unsigned int i;
9177
9178 if (!bgp->rib[afi][safi])
9179 {
9180 vty_out (vty, "%% No RIB exist for the AFI/SAFI%s", VTY_NEWLINE);
9181 return CMD_WARNING;
9182 }
9183
9184 memset (&ts, 0, sizeof (ts));
9185 ts.table = bgp->rib[afi][safi];
9186 thread_execute (bm->master, bgp_table_stats_walker, &ts, 0);
bb46e94f 9187
2815e61f
PJ
9188 vty_out (vty, "BGP %s RIB statistics%s%s",
9189 afi_safi_print (afi, safi), VTY_NEWLINE, VTY_NEWLINE);
9190
9191 for (i = 0; i < BGP_STATS_MAX; i++)
9192 {
9193 if (!table_stats_strs[i])
9194 continue;
9195
9196 switch (i)
9197 {
9198#if 0
9199 case BGP_STATS_ASPATH_AVGHOPS:
9200 case BGP_STATS_ASPATH_AVGSIZE:
9201 case BGP_STATS_AVGPLEN:
9202 vty_out (vty, "%-30s: ", table_stats_strs[i]);
9203 vty_out (vty, "%12.2f",
9204 (float)ts.counts[i] / (float)TALLY_SIGFIG);
9205 break;
9206#endif
9207 case BGP_STATS_ASPATH_TOTHOPS:
9208 case BGP_STATS_ASPATH_TOTSIZE:
9209 vty_out (vty, "%-30s: ", table_stats_strs[i]);
9210 vty_out (vty, "%12.2f",
9211 ts.counts[i] ?
9212 (float)ts.counts[i] /
9213 (float)ts.counts[BGP_STATS_ASPATH_COUNT]
9214 : 0);
9215 break;
9216 case BGP_STATS_TOTPLEN:
9217 vty_out (vty, "%-30s: ", table_stats_strs[i]);
9218 vty_out (vty, "%12.2f",
9219 ts.counts[i] ?
9220 (float)ts.counts[i] /
9221 (float)ts.counts[BGP_STATS_PREFIXES]
9222 : 0);
9223 break;
9224 case BGP_STATS_SPACE:
9225 vty_out (vty, "%-30s: ", table_stats_strs[i]);
9226 vty_out (vty, "%12llu%s", ts.counts[i], VTY_NEWLINE);
9227 if (ts.counts[BGP_STATS_MAXBITLEN] < 9)
9228 break;
30a2231a 9229 vty_out (vty, "%30s: ", "%% announced ");
2815e61f
PJ
9230 vty_out (vty, "%12.2f%s",
9231 100 * (float)ts.counts[BGP_STATS_SPACE] /
56395af7 9232 (float)((uint64_t)1UL << ts.counts[BGP_STATS_MAXBITLEN]),
2815e61f
PJ
9233 VTY_NEWLINE);
9234 vty_out (vty, "%30s: ", "/8 equivalent ");
9235 vty_out (vty, "%12.2f%s",
9236 (float)ts.counts[BGP_STATS_SPACE] /
9237 (float)(1UL << (ts.counts[BGP_STATS_MAXBITLEN] - 8)),
9238 VTY_NEWLINE);
9239 if (ts.counts[BGP_STATS_MAXBITLEN] < 25)
9240 break;
9241 vty_out (vty, "%30s: ", "/24 equivalent ");
9242 vty_out (vty, "%12.2f",
9243 (float)ts.counts[BGP_STATS_SPACE] /
9244 (float)(1UL << (ts.counts[BGP_STATS_MAXBITLEN] - 24)));
9245 break;
9246 default:
9247 vty_out (vty, "%-30s: ", table_stats_strs[i]);
9248 vty_out (vty, "%12llu", ts.counts[i]);
9249 }
9250
9251 vty_out (vty, "%s", VTY_NEWLINE);
9252 }
9253 return CMD_SUCCESS;
9254}
9255
9256static int
9257bgp_table_stats_vty (struct vty *vty, const char *name,
9258 const char *afi_str, const char *safi_str)
9259{
9260 struct bgp *bgp;
9261 afi_t afi;
9262 safi_t safi;
9263
9264 if (name)
9265 bgp = bgp_lookup_by_name (name);
9266 else
9267 bgp = bgp_get_default ();
9268
9269 if (!bgp)
9270 {
9271 vty_out (vty, "%% No such BGP instance exist%s", VTY_NEWLINE);
9272 return CMD_WARNING;
9273 }
9274 if (strncmp (afi_str, "ipv", 3) == 0)
9275 {
9276 if (strncmp (afi_str, "ipv4", 4) == 0)
9277 afi = AFI_IP;
9278 else if (strncmp (afi_str, "ipv6", 4) == 0)
9279 afi = AFI_IP6;
9280 else
9281 {
9282 vty_out (vty, "%% Invalid address family %s%s",
9283 afi_str, VTY_NEWLINE);
9284 return CMD_WARNING;
9285 }
9286 if (strncmp (safi_str, "m", 1) == 0)
9287 safi = SAFI_MULTICAST;
9288 else if (strncmp (safi_str, "u", 1) == 0)
9289 safi = SAFI_UNICAST;
9290 else if (strncmp (safi_str, "vpnv4", 5) == 0)
9291 safi = BGP_SAFI_VPNV4;
9292 else if (strncmp (safi_str, "vpnv6", 6) == 0)
9293 safi = BGP_SAFI_VPNV6;
9294 else
9295 {
9296 vty_out (vty, "%% Invalid subsequent address family %s%s",
9297 safi_str, VTY_NEWLINE);
9298 return CMD_WARNING;
9299 }
9300 }
9301 else
9302 {
9303 vty_out (vty, "%% Invalid address family %s%s",
9304 afi_str, VTY_NEWLINE);
9305 return CMD_WARNING;
9306 }
9307
9308 if ((afi == AFI_IP && safi == BGP_SAFI_VPNV6)
9309 || (afi == AFI_IP6 && safi == BGP_SAFI_VPNV4))
9310 {
9311 vty_out (vty, "%% Invalid subsequent address family %s for %s%s",
9312 afi_str, safi_str, VTY_NEWLINE);
9313 return CMD_WARNING;
9314 }
9315 return bgp_table_stats (vty, bgp, afi, safi);
9316}
9317
9318DEFUN (show_bgp_statistics,
9319 show_bgp_statistics_cmd,
9320 "show bgp (ipv4|ipv6) (unicast|multicast) statistics",
9321 SHOW_STR
9322 BGP_STR
9323 "Address family\n"
9324 "Address family\n"
9325 "Address Family modifier\n"
9326 "Address Family modifier\n"
9327 "BGP RIB advertisement statistics\n")
9328{
9329 return bgp_table_stats_vty (vty, NULL, argv[0], argv[1]);
9330}
9331
9332ALIAS (show_bgp_statistics,
9333 show_bgp_statistics_vpnv4_cmd,
9334 "show bgp (ipv4) (vpnv4) statistics",
9335 SHOW_STR
9336 BGP_STR
9337 "Address family\n"
9338 "Address Family modifier\n"
9339 "BGP RIB advertisement statistics\n")
9340
9341DEFUN (show_bgp_statistics_view,
9342 show_bgp_statistics_view_cmd,
9343 "show bgp view WORD (ipv4|ipv6) (unicast|multicast) statistics",
9344 SHOW_STR
9345 BGP_STR
9346 "BGP view\n"
9347 "Address family\n"
9348 "Address family\n"
9349 "Address Family modifier\n"
9350 "Address Family modifier\n"
9351 "BGP RIB advertisement statistics\n")
9352{
9353 return bgp_table_stats_vty (vty, NULL, argv[0], argv[1]);
9354}
9355
9356ALIAS (show_bgp_statistics_view,
9357 show_bgp_statistics_view_vpnv4_cmd,
9358 "show bgp view WORD (ipv4) (vpnv4) statistics",
9359 SHOW_STR
9360 BGP_STR
9361 "BGP view\n"
9362 "Address family\n"
9363 "Address Family modifier\n"
9364 "BGP RIB advertisement statistics\n")
9365\f
ff7924f6
PJ
9366enum bgp_pcounts
9367{
9368 PCOUNT_ADJ_IN = 0,
9369 PCOUNT_DAMPED,
9370 PCOUNT_REMOVED,
9371 PCOUNT_HISTORY,
9372 PCOUNT_STALE,
9373 PCOUNT_VALID,
9374 PCOUNT_ALL,
9375 PCOUNT_COUNTED,
9376 PCOUNT_PFCNT, /* the figure we display to users */
9377 PCOUNT_MAX,
9378};
9379
9380static const char *pcount_strs[] =
9381{
9382 [PCOUNT_ADJ_IN] = "Adj-in",
9383 [PCOUNT_DAMPED] = "Damped",
9384 [PCOUNT_REMOVED] = "Removed",
9385 [PCOUNT_HISTORY] = "History",
9386 [PCOUNT_STALE] = "Stale",
9387 [PCOUNT_VALID] = "Valid",
9388 [PCOUNT_ALL] = "All RIB",
9389 [PCOUNT_COUNTED] = "PfxCt counted",
9390 [PCOUNT_PFCNT] = "Useable",
9391 [PCOUNT_MAX] = NULL,
9392};
9393
2815e61f
PJ
9394struct peer_pcounts
9395{
9396 unsigned int count[PCOUNT_MAX];
9397 const struct peer *peer;
9398 const struct bgp_table *table;
9399};
9400
ff7924f6 9401static int
2815e61f 9402bgp_peer_count_walker (struct thread *t)
ff7924f6
PJ
9403{
9404 struct bgp_node *rn;
2815e61f
PJ
9405 struct peer_pcounts *pc = THREAD_ARG (t);
9406 const struct peer *peer = pc->peer;
ff7924f6 9407
2815e61f 9408 for (rn = bgp_table_top (pc->table); rn; rn = bgp_route_next (rn))
ff7924f6
PJ
9409 {
9410 struct bgp_adj_in *ain;
2815e61f 9411 struct bgp_info *ri;
ff7924f6
PJ
9412
9413 for (ain = rn->adj_in; ain; ain = ain->next)
9414 if (ain->peer == peer)
2815e61f 9415 pc->count[PCOUNT_ADJ_IN]++;
ff7924f6 9416
ff7924f6
PJ
9417 for (ri = rn->info; ri; ri = ri->next)
9418 {
9419 char buf[SU_ADDRSTRLEN];
9420
9421 if (ri->peer != peer)
9422 continue;
9423
2815e61f 9424 pc->count[PCOUNT_ALL]++;
ff7924f6
PJ
9425
9426 if (CHECK_FLAG (ri->flags, BGP_INFO_DAMPED))
2815e61f 9427 pc->count[PCOUNT_DAMPED]++;
ff7924f6 9428 if (CHECK_FLAG (ri->flags, BGP_INFO_HISTORY))
2815e61f 9429 pc->count[PCOUNT_HISTORY]++;
ff7924f6 9430 if (CHECK_FLAG (ri->flags, BGP_INFO_REMOVED))
2815e61f 9431 pc->count[PCOUNT_REMOVED]++;
ff7924f6 9432 if (CHECK_FLAG (ri->flags, BGP_INFO_STALE))
2815e61f 9433 pc->count[PCOUNT_STALE]++;
ff7924f6 9434 if (CHECK_FLAG (ri->flags, BGP_INFO_VALID))
2815e61f 9435 pc->count[PCOUNT_VALID]++;
1a392d46 9436 if (!CHECK_FLAG (ri->flags, BGP_INFO_UNUSEABLE))
2815e61f 9437 pc->count[PCOUNT_PFCNT]++;
ff7924f6
PJ
9438
9439 if (CHECK_FLAG (ri->flags, BGP_INFO_COUNTED))
9440 {
2815e61f 9441 pc->count[PCOUNT_COUNTED]++;
1a392d46 9442 if (CHECK_FLAG (ri->flags, BGP_INFO_UNUSEABLE))
ff7924f6
PJ
9443 plog_warn (peer->log,
9444 "%s [pcount] %s/%d is counted but flags 0x%x",
9445 peer->host,
9446 inet_ntop(rn->p.family, &rn->p.u.prefix,
9447 buf, SU_ADDRSTRLEN),
9448 rn->p.prefixlen,
9449 ri->flags);
9450 }
9451 else
9452 {
1a392d46 9453 if (!CHECK_FLAG (ri->flags, BGP_INFO_UNUSEABLE))
ff7924f6
PJ
9454 plog_warn (peer->log,
9455 "%s [pcount] %s/%d not counted but flags 0x%x",
9456 peer->host,
9457 inet_ntop(rn->p.family, &rn->p.u.prefix,
9458 buf, SU_ADDRSTRLEN),
9459 rn->p.prefixlen,
9460 ri->flags);
9461 }
9462 }
9463 }
2815e61f
PJ
9464 return 0;
9465}
ff7924f6 9466
2815e61f
PJ
9467static int
9468bgp_peer_counts (struct vty *vty, struct peer *peer, afi_t afi, safi_t safi)
9469{
9470 struct peer_pcounts pcounts = { .peer = peer };
9471 unsigned int i;
9472
9473 if (!peer || !peer->bgp || !peer->afc[afi][safi]
9474 || !peer->bgp->rib[afi][safi])
9475 {
9476 vty_out (vty, "%% No such neighbor or address family%s", VTY_NEWLINE);
9477 return CMD_WARNING;
9478 }
9479
9480 memset (&pcounts, 0, sizeof(pcounts));
9481 pcounts.peer = peer;
9482 pcounts.table = peer->bgp->rib[afi][safi];
9483
9484 /* in-place call via thread subsystem so as to record execution time
9485 * stats for the thread-walk (i.e. ensure this can't be blamed on
9486 * on just vty_read()).
9487 */
9488 thread_execute (bm->master, bgp_peer_count_walker, &pcounts, 0);
9489
ff7924f6
PJ
9490 vty_out (vty, "Prefix counts for %s, %s%s",
9491 peer->host, afi_safi_print (afi, safi), VTY_NEWLINE);
9492 vty_out (vty, "PfxCt: %ld%s", peer->pcount[afi][safi], VTY_NEWLINE);
9493 vty_out (vty, "%sCounts from RIB table walk:%s%s",
9494 VTY_NEWLINE, VTY_NEWLINE, VTY_NEWLINE);
9495
9496 for (i = 0; i < PCOUNT_MAX; i++)
2815e61f
PJ
9497 vty_out (vty, "%20s: %-10d%s",
9498 pcount_strs[i], pcounts.count[i], VTY_NEWLINE);
ff7924f6 9499
2815e61f 9500 if (pcounts.count[PCOUNT_PFCNT] != peer->pcount[afi][safi])
ff7924f6
PJ
9501 {
9502 vty_out (vty, "%s [pcount] PfxCt drift!%s",
9503 peer->host, VTY_NEWLINE);
9504 vty_out (vty, "Please report this bug, with the above command output%s",
9505 VTY_NEWLINE);
9506 }
9507
9508 return CMD_SUCCESS;
9509}
9510
9511DEFUN (show_ip_bgp_neighbor_prefix_counts,
9512 show_ip_bgp_neighbor_prefix_counts_cmd,
9513 "show ip bgp neighbors (A.B.C.D|X:X::X:X) prefix-counts",
9514 SHOW_STR
9515 IP_STR
9516 BGP_STR
9517 "Detailed information on TCP and BGP neighbor connections\n"
9518 "Neighbor to display information about\n"
9519 "Neighbor to display information about\n"
9520 "Display detailed prefix count information\n")
9521{
9522 struct peer *peer;
9523
9524 peer = peer_lookup_in_view (vty, NULL, argv[0]);
9525 if (! peer)
9526 return CMD_WARNING;
9527
9528 return bgp_peer_counts (vty, peer, AFI_IP, SAFI_UNICAST);
9529}
9530
9531DEFUN (show_bgp_ipv6_neighbor_prefix_counts,
9532 show_bgp_ipv6_neighbor_prefix_counts_cmd,
9533 "show bgp ipv6 neighbors (A.B.C.D|X:X::X:X) prefix-counts",
9534 SHOW_STR
9535 BGP_STR
9536 "Address family\n"
9537 "Detailed information on TCP and BGP neighbor connections\n"
9538 "Neighbor to display information about\n"
9539 "Neighbor to display information about\n"
9540 "Display detailed prefix count information\n")
9541{
9542 struct peer *peer;
9543
9544 peer = peer_lookup_in_view (vty, NULL, argv[0]);
9545 if (! peer)
9546 return CMD_WARNING;
9547
9548 return bgp_peer_counts (vty, peer, AFI_IP6, SAFI_UNICAST);
9549}
9550
9551DEFUN (show_ip_bgp_ipv4_neighbor_prefix_counts,
9552 show_ip_bgp_ipv4_neighbor_prefix_counts_cmd,
9553 "show ip bgp ipv4 (unicast|multicast) neighbors (A.B.C.D|X:X::X:X) prefix-counts",
9554 SHOW_STR
9555 IP_STR
9556 BGP_STR
9557 "Address family\n"
9558 "Address Family modifier\n"
9559 "Address Family modifier\n"
9560 "Detailed information on TCP and BGP neighbor connections\n"
9561 "Neighbor to display information about\n"
9562 "Neighbor to display information about\n"
9563 "Display detailed prefix count information\n")
9564{
9565 struct peer *peer;
9566
9567 peer = peer_lookup_in_view (vty, NULL, argv[1]);
9568 if (! peer)
9569 return CMD_WARNING;
9570
9571 if (strncmp (argv[0], "m", 1) == 0)
9572 return bgp_peer_counts (vty, peer, AFI_IP, SAFI_MULTICAST);
9573
9574 return bgp_peer_counts (vty, peer, AFI_IP, SAFI_UNICAST);
9575}
9576
9577DEFUN (show_ip_bgp_vpnv4_neighbor_prefix_counts,
9578 show_ip_bgp_vpnv4_neighbor_prefix_counts_cmd,
9579 "show ip bgp vpnv4 all neighbors (A.B.C.D|X:X::X:X) prefix-counts",
9580 SHOW_STR
9581 IP_STR
9582 BGP_STR
9583 "Address family\n"
9584 "Address Family modifier\n"
9585 "Address Family modifier\n"
9586 "Detailed information on TCP and BGP neighbor connections\n"
9587 "Neighbor to display information about\n"
9588 "Neighbor to display information about\n"
9589 "Display detailed prefix count information\n")
9590{
9591 struct peer *peer;
9592
9593 peer = peer_lookup_in_view (vty, NULL, argv[0]);
9594 if (! peer)
9595 return CMD_WARNING;
9596
9597 return bgp_peer_counts (vty, peer, AFI_IP, SAFI_MPLS_VPN);
9598}
9599
9600
94f2b392 9601static void
718e3744 9602show_adj_route (struct vty *vty, struct peer *peer, afi_t afi, safi_t safi,
9603 int in)
9604{
9605 struct bgp_table *table;
9606 struct bgp_adj_in *ain;
9607 struct bgp_adj_out *adj;
9608 unsigned long output_count;
9609 struct bgp_node *rn;
9610 int header1 = 1;
9611 struct bgp *bgp;
9612 int header2 = 1;
9613
bb46e94f 9614 bgp = peer->bgp;
718e3744 9615
9616 if (! bgp)
9617 return;
9618
9619 table = bgp->rib[afi][safi];
9620
9621 output_count = 0;
9622
9623 if (! in && CHECK_FLAG (peer->af_sflags[afi][safi],
9624 PEER_STATUS_DEFAULT_ORIGINATE))
9625 {
9626 vty_out (vty, "BGP table version is 0, local router ID is %s%s", inet_ntoa (bgp->router_id), VTY_NEWLINE);
93406d87 9627 vty_out (vty, BGP_SHOW_SCODE_HEADER, VTY_NEWLINE, VTY_NEWLINE);
9628 vty_out (vty, BGP_SHOW_OCODE_HEADER, VTY_NEWLINE, VTY_NEWLINE);
718e3744 9629
9630 vty_out (vty, "Originating default network 0.0.0.0%s%s",
9631 VTY_NEWLINE, VTY_NEWLINE);
9632 header1 = 0;
9633 }
9634
9635 for (rn = bgp_table_top (table); rn; rn = bgp_route_next (rn))
9636 if (in)
9637 {
9638 for (ain = rn->adj_in; ain; ain = ain->next)
9639 if (ain->peer == peer)
9640 {
9641 if (header1)
9642 {
9643 vty_out (vty, "BGP table version is 0, local router ID is %s%s", inet_ntoa (bgp->router_id), VTY_NEWLINE);
93406d87 9644 vty_out (vty, BGP_SHOW_SCODE_HEADER, VTY_NEWLINE, VTY_NEWLINE);
9645 vty_out (vty, BGP_SHOW_OCODE_HEADER, VTY_NEWLINE, VTY_NEWLINE);
718e3744 9646 header1 = 0;
9647 }
9648 if (header2)
9649 {
9650 vty_out (vty, BGP_SHOW_HEADER, VTY_NEWLINE);
9651 header2 = 0;
9652 }
9653 if (ain->attr)
9654 {
9655 route_vty_out_tmp (vty, &rn->p, ain->attr, safi);
9656 output_count++;
9657 }
9658 }
9659 }
9660 else
9661 {
9662 for (adj = rn->adj_out; adj; adj = adj->next)
9663 if (adj->peer == peer)
9664 {
9665 if (header1)
9666 {
9667 vty_out (vty, "BGP table version is 0, local router ID is %s%s", inet_ntoa (bgp->router_id), VTY_NEWLINE);
93406d87 9668 vty_out (vty, BGP_SHOW_SCODE_HEADER, VTY_NEWLINE, VTY_NEWLINE);
9669 vty_out (vty, BGP_SHOW_OCODE_HEADER, VTY_NEWLINE, VTY_NEWLINE);
718e3744 9670 header1 = 0;
9671 }
9672 if (header2)
9673 {
9674 vty_out (vty, BGP_SHOW_HEADER, VTY_NEWLINE);
9675 header2 = 0;
9676 }
9677 if (adj->attr)
9678 {
9679 route_vty_out_tmp (vty, &rn->p, adj->attr, safi);
9680 output_count++;
9681 }
9682 }
9683 }
9684
9685 if (output_count != 0)
9686 vty_out (vty, "%sTotal number of prefixes %ld%s",
9687 VTY_NEWLINE, output_count, VTY_NEWLINE);
9688}
9689
94f2b392 9690static int
bb46e94f 9691peer_adj_routes (struct vty *vty, struct peer *peer, afi_t afi, safi_t safi, int in)
9692{
718e3744 9693 if (! peer || ! peer->afc[afi][safi])
9694 {
9695 vty_out (vty, "%% No such neighbor or address family%s", VTY_NEWLINE);
9696 return CMD_WARNING;
9697 }
9698
9699 if (in && ! CHECK_FLAG (peer->af_flags[afi][safi], PEER_FLAG_SOFT_RECONFIG))
9700 {
9701 vty_out (vty, "%% Inbound soft reconfiguration not enabled%s",
9702 VTY_NEWLINE);
9703 return CMD_WARNING;
9704 }
9705
9706 show_adj_route (vty, peer, afi, safi, in);
9707
9708 return CMD_SUCCESS;
9709}
9710
2a71e9ce
TP
9711DEFUN (show_ip_bgp_view_neighbor_advertised_route,
9712 show_ip_bgp_view_neighbor_advertised_route_cmd,
9713 "show ip bgp view WORD neighbors (A.B.C.D|X:X::X:X) advertised-routes",
718e3744 9714 SHOW_STR
9715 IP_STR
9716 BGP_STR
2a71e9ce
TP
9717 "BGP view\n"
9718 "View name\n"
718e3744 9719 "Detailed information on TCP and BGP neighbor connections\n"
9720 "Neighbor to display information about\n"
9721 "Neighbor to display information about\n"
9722 "Display the routes advertised to a BGP neighbor\n")
9723{
bb46e94f 9724 struct peer *peer;
9725
2a71e9ce
TP
9726 if (argc == 2)
9727 peer = peer_lookup_in_view (vty, argv[0], argv[1]);
9728 else
9729 peer = peer_lookup_in_view (vty, NULL, argv[0]);
9730
bb46e94f 9731 if (! peer)
9732 return CMD_WARNING;
9733
9734 return peer_adj_routes (vty, peer, AFI_IP, SAFI_UNICAST, 0);
718e3744 9735}
9736
2a71e9ce
TP
9737ALIAS (show_ip_bgp_view_neighbor_advertised_route,
9738 show_ip_bgp_neighbor_advertised_route_cmd,
9739 "show ip bgp neighbors (A.B.C.D|X:X::X:X) advertised-routes",
9740 SHOW_STR
9741 IP_STR
9742 BGP_STR
9743 "Detailed information on TCP and BGP neighbor connections\n"
9744 "Neighbor to display information about\n"
9745 "Neighbor to display information about\n"
9746 "Display the routes advertised to a BGP neighbor\n")
9747
718e3744 9748DEFUN (show_ip_bgp_ipv4_neighbor_advertised_route,
9749 show_ip_bgp_ipv4_neighbor_advertised_route_cmd,
9750 "show ip bgp ipv4 (unicast|multicast) neighbors (A.B.C.D|X:X::X:X) advertised-routes",
9751 SHOW_STR
9752 IP_STR
9753 BGP_STR
9754 "Address family\n"
9755 "Address Family modifier\n"
9756 "Address Family modifier\n"
9757 "Detailed information on TCP and BGP neighbor connections\n"
9758 "Neighbor to display information about\n"
9759 "Neighbor to display information about\n"
9760 "Display the routes advertised to a BGP neighbor\n")
9761{
bb46e94f 9762 struct peer *peer;
9763
9764 peer = peer_lookup_in_view (vty, NULL, argv[1]);
9765 if (! peer)
9766 return CMD_WARNING;
9767
718e3744 9768 if (strncmp (argv[0], "m", 1) == 0)
bb46e94f 9769 return peer_adj_routes (vty, peer, AFI_IP, SAFI_MULTICAST, 0);
718e3744 9770
bb46e94f 9771 return peer_adj_routes (vty, peer, AFI_IP, SAFI_UNICAST, 0);
718e3744 9772}
9773
9774#ifdef HAVE_IPV6
bb46e94f 9775DEFUN (show_bgp_view_neighbor_advertised_route,
9776 show_bgp_view_neighbor_advertised_route_cmd,
9777 "show bgp view WORD neighbors (A.B.C.D|X:X::X:X) advertised-routes",
718e3744 9778 SHOW_STR
9779 BGP_STR
bb46e94f 9780 "BGP view\n"
9781 "View name\n"
718e3744 9782 "Detailed information on TCP and BGP neighbor connections\n"
9783 "Neighbor to display information about\n"
9784 "Neighbor to display information about\n"
9785 "Display the routes advertised to a BGP neighbor\n")
9786{
bb46e94f 9787 struct peer *peer;
9788
9789 if (argc == 2)
9790 peer = peer_lookup_in_view (vty, argv[0], argv[1]);
9791 else
9792 peer = peer_lookup_in_view (vty, NULL, argv[0]);
9793
9794 if (! peer)
9795 return CMD_WARNING;
9796
9797 return peer_adj_routes (vty, peer, AFI_IP6, SAFI_UNICAST, 0);
9798}
9799
9800ALIAS (show_bgp_view_neighbor_advertised_route,
9801 show_bgp_view_ipv6_neighbor_advertised_route_cmd,
9802 "show bgp view WORD ipv6 neighbors (A.B.C.D|X:X::X:X) advertised-routes",
9803 SHOW_STR
9804 BGP_STR
9805 "BGP view\n"
9806 "View name\n"
9807 "Address family\n"
9808 "Detailed information on TCP and BGP neighbor connections\n"
9809 "Neighbor to display information about\n"
9810 "Neighbor to display information about\n"
9811 "Display the routes advertised to a BGP neighbor\n")
9812
9813DEFUN (show_bgp_view_neighbor_received_routes,
9814 show_bgp_view_neighbor_received_routes_cmd,
9815 "show bgp view WORD neighbors (A.B.C.D|X:X::X:X) received-routes",
9816 SHOW_STR
9817 BGP_STR
9818 "BGP view\n"
9819 "View name\n"
9820 "Detailed information on TCP and BGP neighbor connections\n"
9821 "Neighbor to display information about\n"
9822 "Neighbor to display information about\n"
9823 "Display the received routes from neighbor\n")
9824{
9825 struct peer *peer;
9826
9827 if (argc == 2)
9828 peer = peer_lookup_in_view (vty, argv[0], argv[1]);
9829 else
9830 peer = peer_lookup_in_view (vty, NULL, argv[0]);
9831
9832 if (! peer)
9833 return CMD_WARNING;
9834
9835 return peer_adj_routes (vty, peer, AFI_IP6, SAFI_UNICAST, 1);
718e3744 9836}
9837
bb46e94f 9838ALIAS (show_bgp_view_neighbor_received_routes,
9839 show_bgp_view_ipv6_neighbor_received_routes_cmd,
9840 "show bgp view WORD ipv6 neighbors (A.B.C.D|X:X::X:X) received-routes",
9841 SHOW_STR
9842 BGP_STR
9843 "BGP view\n"
9844 "View name\n"
9845 "Address family\n"
9846 "Detailed information on TCP and BGP neighbor connections\n"
9847 "Neighbor to display information about\n"
9848 "Neighbor to display information about\n"
9849 "Display the received routes from neighbor\n")
9850
9851ALIAS (show_bgp_view_neighbor_advertised_route,
9852 show_bgp_neighbor_advertised_route_cmd,
9853 "show bgp neighbors (A.B.C.D|X:X::X:X) advertised-routes",
9854 SHOW_STR
9855 BGP_STR
9856 "Detailed information on TCP and BGP neighbor connections\n"
9857 "Neighbor to display information about\n"
9858 "Neighbor to display information about\n"
9859 "Display the routes advertised to a BGP neighbor\n")
9860
9861ALIAS (show_bgp_view_neighbor_advertised_route,
718e3744 9862 show_bgp_ipv6_neighbor_advertised_route_cmd,
9863 "show bgp ipv6 neighbors (A.B.C.D|X:X::X:X) advertised-routes",
9864 SHOW_STR
9865 BGP_STR
9866 "Address family\n"
9867 "Detailed information on TCP and BGP neighbor connections\n"
9868 "Neighbor to display information about\n"
9869 "Neighbor to display information about\n"
9870 "Display the routes advertised to a BGP neighbor\n")
9871
9872/* old command */
bb46e94f 9873ALIAS (show_bgp_view_neighbor_advertised_route,
718e3744 9874 ipv6_bgp_neighbor_advertised_route_cmd,
9875 "show ipv6 bgp neighbors (A.B.C.D|X:X::X:X) advertised-routes",
9876 SHOW_STR
9877 IPV6_STR
9878 BGP_STR
9879 "Detailed information on TCP and BGP neighbor connections\n"
9880 "Neighbor to display information about\n"
9881 "Neighbor to display information about\n"
9882 "Display the routes advertised to a BGP neighbor\n")
bb46e94f 9883
718e3744 9884/* old command */
9885DEFUN (ipv6_mbgp_neighbor_advertised_route,
9886 ipv6_mbgp_neighbor_advertised_route_cmd,
9887 "show ipv6 mbgp neighbors (A.B.C.D|X:X::X:X) advertised-routes",
9888 SHOW_STR
9889 IPV6_STR
9890 MBGP_STR
9891 "Detailed information on TCP and BGP neighbor connections\n"
9892 "Neighbor to display information about\n"
9893 "Neighbor to display information about\n"
9894 "Display the routes advertised to a BGP neighbor\n")
9895{
bb46e94f 9896 struct peer *peer;
9897
9898 peer = peer_lookup_in_view (vty, NULL, argv[0]);
9899 if (! peer)
9900 return CMD_WARNING;
9901
9902 return peer_adj_routes (vty, peer, AFI_IP6, SAFI_MULTICAST, 0);
718e3744 9903}
9904#endif /* HAVE_IPV6 */
9905\f
2a71e9ce
TP
9906DEFUN (show_ip_bgp_view_neighbor_received_routes,
9907 show_ip_bgp_view_neighbor_received_routes_cmd,
9908 "show ip bgp view WORD neighbors (A.B.C.D|X:X::X:X) received-routes",
718e3744 9909 SHOW_STR
9910 IP_STR
9911 BGP_STR
2a71e9ce
TP
9912 "BGP view\n"
9913 "View name\n"
718e3744 9914 "Detailed information on TCP and BGP neighbor connections\n"
9915 "Neighbor to display information about\n"
9916 "Neighbor to display information about\n"
9917 "Display the received routes from neighbor\n")
9918{
bb46e94f 9919 struct peer *peer;
9920
2a71e9ce
TP
9921 if (argc == 2)
9922 peer = peer_lookup_in_view (vty, argv[0], argv[1]);
9923 else
9924 peer = peer_lookup_in_view (vty, NULL, argv[0]);
9925
bb46e94f 9926 if (! peer)
9927 return CMD_WARNING;
9928
9929 return peer_adj_routes (vty, peer, AFI_IP, SAFI_UNICAST, 1);
718e3744 9930}
9931
2a71e9ce
TP
9932ALIAS (show_ip_bgp_view_neighbor_received_routes,
9933 show_ip_bgp_neighbor_received_routes_cmd,
9934 "show ip bgp neighbors (A.B.C.D|X:X::X:X) received-routes",
9935 SHOW_STR
9936 IP_STR
9937 BGP_STR
9938 "Detailed information on TCP and BGP neighbor connections\n"
9939 "Neighbor to display information about\n"
9940 "Neighbor to display information about\n"
9941 "Display the received routes from neighbor\n")
9942
718e3744 9943DEFUN (show_ip_bgp_ipv4_neighbor_received_routes,
9944 show_ip_bgp_ipv4_neighbor_received_routes_cmd,
9945 "show ip bgp ipv4 (unicast|multicast) neighbors (A.B.C.D|X:X::X:X) received-routes",
9946 SHOW_STR
9947 IP_STR
9948 BGP_STR
9949 "Address family\n"
9950 "Address Family modifier\n"
9951 "Address Family modifier\n"
9952 "Detailed information on TCP and BGP neighbor connections\n"
9953 "Neighbor to display information about\n"
9954 "Neighbor to display information about\n"
9955 "Display the received routes from neighbor\n")
9956{
bb46e94f 9957 struct peer *peer;
9958
9959 peer = peer_lookup_in_view (vty, NULL, argv[1]);
9960 if (! peer)
9961 return CMD_WARNING;
9962
718e3744 9963 if (strncmp (argv[0], "m", 1) == 0)
bb46e94f 9964 return peer_adj_routes (vty, peer, AFI_IP, SAFI_MULTICAST, 1);
718e3744 9965
bb46e94f 9966 return peer_adj_routes (vty, peer, AFI_IP, SAFI_UNICAST, 1);
718e3744 9967}
9968
9969DEFUN (show_ip_bgp_neighbor_received_prefix_filter,
9970 show_ip_bgp_neighbor_received_prefix_filter_cmd,
9971 "show ip bgp neighbors (A.B.C.D|X:X::X:X) received prefix-filter",
9972 SHOW_STR
9973 IP_STR
9974 BGP_STR
9975 "Detailed information on TCP and BGP neighbor connections\n"
9976 "Neighbor to display information about\n"
9977 "Neighbor to display information about\n"
9978 "Display information received from a BGP neighbor\n"
9979 "Display the prefixlist filter\n")
9980{
9981 char name[BUFSIZ];
9982 union sockunion *su;
9983 struct peer *peer;
9984 int count;
9985
9986 su = sockunion_str2su (argv[0]);
9987 if (su == NULL)
9988 return CMD_WARNING;
9989
9990 peer = peer_lookup (NULL, su);
9991 if (! peer)
9992 return CMD_WARNING;
9993
9994 sprintf (name, "%s.%d.%d", peer->host, AFI_IP, SAFI_UNICAST);
9995 count = prefix_bgp_show_prefix_list (NULL, AFI_IP, name);
9996 if (count)
9997 {
9998 vty_out (vty, "Address family: IPv4 Unicast%s", VTY_NEWLINE);
9999 prefix_bgp_show_prefix_list (vty, AFI_IP, name);
10000 }
10001
10002 return CMD_SUCCESS;
10003}
10004
10005DEFUN (show_ip_bgp_ipv4_neighbor_received_prefix_filter,
10006 show_ip_bgp_ipv4_neighbor_received_prefix_filter_cmd,
10007 "show ip bgp ipv4 (unicast|multicast) neighbors (A.B.C.D|X:X::X:X) received prefix-filter",
10008 SHOW_STR
10009 IP_STR
10010 BGP_STR
10011 "Address family\n"
10012 "Address Family modifier\n"
10013 "Address Family modifier\n"
10014 "Detailed information on TCP and BGP neighbor connections\n"
10015 "Neighbor to display information about\n"
10016 "Neighbor to display information about\n"
10017 "Display information received from a BGP neighbor\n"
10018 "Display the prefixlist filter\n")
10019{
10020 char name[BUFSIZ];
10021 union sockunion *su;
10022 struct peer *peer;
10023 int count;
10024
10025 su = sockunion_str2su (argv[1]);
10026 if (su == NULL)
10027 return CMD_WARNING;
10028
10029 peer = peer_lookup (NULL, su);
10030 if (! peer)
10031 return CMD_WARNING;
10032
10033 if (strncmp (argv[0], "m", 1) == 0)
10034 {
10035 sprintf (name, "%s.%d.%d", peer->host, AFI_IP, SAFI_MULTICAST);
10036 count = prefix_bgp_show_prefix_list (NULL, AFI_IP, name);
10037 if (count)
10038 {
10039 vty_out (vty, "Address family: IPv4 Multicast%s", VTY_NEWLINE);
10040 prefix_bgp_show_prefix_list (vty, AFI_IP, name);
10041 }
10042 }
10043 else
10044 {
10045 sprintf (name, "%s.%d.%d", peer->host, AFI_IP, SAFI_UNICAST);
10046 count = prefix_bgp_show_prefix_list (NULL, AFI_IP, name);
10047 if (count)
10048 {
10049 vty_out (vty, "Address family: IPv4 Unicast%s", VTY_NEWLINE);
10050 prefix_bgp_show_prefix_list (vty, AFI_IP, name);
10051 }
10052 }
10053
10054 return CMD_SUCCESS;
10055}
10056
10057
10058#ifdef HAVE_IPV6
bb46e94f 10059ALIAS (show_bgp_view_neighbor_received_routes,
718e3744 10060 show_bgp_neighbor_received_routes_cmd,
10061 "show bgp neighbors (A.B.C.D|X:X::X:X) received-routes",
10062 SHOW_STR
10063 BGP_STR
10064 "Detailed information on TCP and BGP neighbor connections\n"
10065 "Neighbor to display information about\n"
10066 "Neighbor to display information about\n"
10067 "Display the received routes from neighbor\n")
718e3744 10068
bb46e94f 10069ALIAS (show_bgp_view_neighbor_received_routes,
718e3744 10070 show_bgp_ipv6_neighbor_received_routes_cmd,
10071 "show bgp ipv6 neighbors (A.B.C.D|X:X::X:X) received-routes",
10072 SHOW_STR
10073 BGP_STR
10074 "Address family\n"
10075 "Detailed information on TCP and BGP neighbor connections\n"
10076 "Neighbor to display information about\n"
10077 "Neighbor to display information about\n"
10078 "Display the received routes from neighbor\n")
10079
10080DEFUN (show_bgp_neighbor_received_prefix_filter,
10081 show_bgp_neighbor_received_prefix_filter_cmd,
10082 "show bgp neighbors (A.B.C.D|X:X::X:X) received prefix-filter",
10083 SHOW_STR
10084 BGP_STR
10085 "Detailed information on TCP and BGP neighbor connections\n"
10086 "Neighbor to display information about\n"
10087 "Neighbor to display information about\n"
10088 "Display information received from a BGP neighbor\n"
10089 "Display the prefixlist filter\n")
10090{
10091 char name[BUFSIZ];
10092 union sockunion *su;
10093 struct peer *peer;
10094 int count;
10095
10096 su = sockunion_str2su (argv[0]);
10097 if (su == NULL)
10098 return CMD_WARNING;
10099
10100 peer = peer_lookup (NULL, su);
10101 if (! peer)
10102 return CMD_WARNING;
10103
10104 sprintf (name, "%s.%d.%d", peer->host, AFI_IP6, SAFI_UNICAST);
10105 count = prefix_bgp_show_prefix_list (NULL, AFI_IP6, name);
10106 if (count)
10107 {
10108 vty_out (vty, "Address family: IPv6 Unicast%s", VTY_NEWLINE);
10109 prefix_bgp_show_prefix_list (vty, AFI_IP6, name);
10110 }
10111
10112 return CMD_SUCCESS;
10113}
10114
10115ALIAS (show_bgp_neighbor_received_prefix_filter,
10116 show_bgp_ipv6_neighbor_received_prefix_filter_cmd,
10117 "show bgp ipv6 neighbors (A.B.C.D|X:X::X:X) received prefix-filter",
10118 SHOW_STR
10119 BGP_STR
10120 "Address family\n"
10121 "Detailed information on TCP and BGP neighbor connections\n"
10122 "Neighbor to display information about\n"
10123 "Neighbor to display information about\n"
10124 "Display information received from a BGP neighbor\n"
10125 "Display the prefixlist filter\n")
10126
10127/* old command */
bb46e94f 10128ALIAS (show_bgp_view_neighbor_received_routes,
718e3744 10129 ipv6_bgp_neighbor_received_routes_cmd,
10130 "show ipv6 bgp neighbors (A.B.C.D|X:X::X:X) received-routes",
10131 SHOW_STR
10132 IPV6_STR
10133 BGP_STR
10134 "Detailed information on TCP and BGP neighbor connections\n"
10135 "Neighbor to display information about\n"
10136 "Neighbor to display information about\n"
10137 "Display the received routes from neighbor\n")
718e3744 10138
10139/* old command */
10140DEFUN (ipv6_mbgp_neighbor_received_routes,
10141 ipv6_mbgp_neighbor_received_routes_cmd,
10142 "show ipv6 mbgp neighbors (A.B.C.D|X:X::X:X) received-routes",
10143 SHOW_STR
10144 IPV6_STR
10145 MBGP_STR
10146 "Detailed information on TCP and BGP neighbor connections\n"
10147 "Neighbor to display information about\n"
10148 "Neighbor to display information about\n"
10149 "Display the received routes from neighbor\n")
10150{
bb46e94f 10151 struct peer *peer;
10152
10153 peer = peer_lookup_in_view (vty, NULL, argv[0]);
10154 if (! peer)
10155 return CMD_WARNING;
10156
10157 return peer_adj_routes (vty, peer, AFI_IP6, SAFI_MULTICAST, 1);
10158}
10159
10160DEFUN (show_bgp_view_neighbor_received_prefix_filter,
10161 show_bgp_view_neighbor_received_prefix_filter_cmd,
10162 "show bgp view WORD neighbors (A.B.C.D|X:X::X:X) received prefix-filter",
10163 SHOW_STR
10164 BGP_STR
10165 "BGP view\n"
10166 "View name\n"
10167 "Detailed information on TCP and BGP neighbor connections\n"
10168 "Neighbor to display information about\n"
10169 "Neighbor to display information about\n"
10170 "Display information received from a BGP neighbor\n"
10171 "Display the prefixlist filter\n")
10172{
10173 char name[BUFSIZ];
10174 union sockunion *su;
10175 struct peer *peer;
10176 struct bgp *bgp;
10177 int count;
10178
10179 /* BGP structure lookup. */
10180 bgp = bgp_lookup_by_name (argv[0]);
10181 if (bgp == NULL)
10182 {
10183 vty_out (vty, "Can't find BGP view %s%s", argv[0], VTY_NEWLINE);
10184 return CMD_WARNING;
10185 }
10186
10187 su = sockunion_str2su (argv[1]);
10188 if (su == NULL)
10189 return CMD_WARNING;
10190
10191 peer = peer_lookup (bgp, su);
10192 if (! peer)
10193 return CMD_WARNING;
10194
10195 sprintf (name, "%s.%d.%d", peer->host, AFI_IP6, SAFI_UNICAST);
10196 count = prefix_bgp_show_prefix_list (NULL, AFI_IP6, name);
10197 if (count)
10198 {
10199 vty_out (vty, "Address family: IPv6 Unicast%s", VTY_NEWLINE);
10200 prefix_bgp_show_prefix_list (vty, AFI_IP6, name);
10201 }
10202
10203 return CMD_SUCCESS;
718e3744 10204}
bb46e94f 10205
10206ALIAS (show_bgp_view_neighbor_received_prefix_filter,
10207 show_bgp_view_ipv6_neighbor_received_prefix_filter_cmd,
10208 "show bgp view WORD ipv6 neighbors (A.B.C.D|X:X::X:X) received prefix-filter",
10209 SHOW_STR
10210 BGP_STR
10211 "BGP view\n"
10212 "View name\n"
10213 "Address family\n"
10214 "Detailed information on TCP and BGP neighbor connections\n"
10215 "Neighbor to display information about\n"
10216 "Neighbor to display information about\n"
10217 "Display information received from a BGP neighbor\n"
10218 "Display the prefixlist filter\n")
718e3744 10219#endif /* HAVE_IPV6 */
10220\f
94f2b392 10221static int
bb46e94f 10222bgp_show_neighbor_route (struct vty *vty, struct peer *peer, afi_t afi,
718e3744 10223 safi_t safi, enum bgp_show_type type)
10224{
718e3744 10225 if (! peer || ! peer->afc[afi][safi])
10226 {
10227 vty_out (vty, "%% No such neighbor or address family%s", VTY_NEWLINE);
718e3744 10228 return CMD_WARNING;
10229 }
10230
5a646650 10231 return bgp_show (vty, peer->bgp, afi, safi, type, &peer->su);
718e3744 10232}
10233
10234DEFUN (show_ip_bgp_neighbor_routes,
10235 show_ip_bgp_neighbor_routes_cmd,
10236 "show ip bgp neighbors (A.B.C.D|X:X::X:X) routes",
10237 SHOW_STR
10238 IP_STR
10239 BGP_STR
10240 "Detailed information on TCP and BGP neighbor connections\n"
10241 "Neighbor to display information about\n"
10242 "Neighbor to display information about\n"
10243 "Display routes learned from neighbor\n")
10244{
bb46e94f 10245 struct peer *peer;
10246
10247 peer = peer_lookup_in_view (vty, NULL, argv[0]);
10248 if (! peer)
10249 return CMD_WARNING;
10250
10251 return bgp_show_neighbor_route (vty, peer, AFI_IP, SAFI_UNICAST,
718e3744 10252 bgp_show_type_neighbor);
10253}
10254
10255DEFUN (show_ip_bgp_neighbor_flap,
10256 show_ip_bgp_neighbor_flap_cmd,
10257 "show ip bgp neighbors (A.B.C.D|X:X::X:X) flap-statistics",
10258 SHOW_STR
10259 IP_STR
10260 BGP_STR
10261 "Detailed information on TCP and BGP neighbor connections\n"
10262 "Neighbor to display information about\n"
10263 "Neighbor to display information about\n"
10264 "Display flap statistics of the routes learned from neighbor\n")
10265{
bb46e94f 10266 struct peer *peer;
10267
10268 peer = peer_lookup_in_view (vty, NULL, argv[0]);
10269 if (! peer)
10270 return CMD_WARNING;
10271
10272 return bgp_show_neighbor_route (vty, peer, AFI_IP, SAFI_UNICAST,
718e3744 10273 bgp_show_type_flap_neighbor);
10274}
10275
10276DEFUN (show_ip_bgp_neighbor_damp,
10277 show_ip_bgp_neighbor_damp_cmd,
10278 "show ip bgp neighbors (A.B.C.D|X:X::X:X) dampened-routes",
10279 SHOW_STR
10280 IP_STR
10281 BGP_STR
10282 "Detailed information on TCP and BGP neighbor connections\n"
10283 "Neighbor to display information about\n"
10284 "Neighbor to display information about\n"
10285 "Display the dampened routes received from neighbor\n")
10286{
bb46e94f 10287 struct peer *peer;
10288
10289 peer = peer_lookup_in_view (vty, NULL, argv[0]);
10290 if (! peer)
10291 return CMD_WARNING;
10292
10293 return bgp_show_neighbor_route (vty, peer, AFI_IP, SAFI_UNICAST,
718e3744 10294 bgp_show_type_damp_neighbor);
10295}
10296
10297DEFUN (show_ip_bgp_ipv4_neighbor_routes,
10298 show_ip_bgp_ipv4_neighbor_routes_cmd,
10299 "show ip bgp ipv4 (unicast|multicast) neighbors (A.B.C.D|X:X::X:X) routes",
10300 SHOW_STR
10301 IP_STR
10302 BGP_STR
10303 "Address family\n"
10304 "Address Family modifier\n"
10305 "Address Family modifier\n"
10306 "Detailed information on TCP and BGP neighbor connections\n"
10307 "Neighbor to display information about\n"
10308 "Neighbor to display information about\n"
10309 "Display routes learned from neighbor\n")
10310{
bb46e94f 10311 struct peer *peer;
10312
10313 peer = peer_lookup_in_view (vty, NULL, argv[1]);
10314 if (! peer)
10315 return CMD_WARNING;
10316
718e3744 10317 if (strncmp (argv[0], "m", 1) == 0)
bb46e94f 10318 return bgp_show_neighbor_route (vty, peer, AFI_IP, SAFI_MULTICAST,
718e3744 10319 bgp_show_type_neighbor);
10320
bb46e94f 10321 return bgp_show_neighbor_route (vty, peer, AFI_IP, SAFI_UNICAST,
718e3744 10322 bgp_show_type_neighbor);
10323}
bb46e94f 10324
fee0f4c6 10325DEFUN (show_ip_bgp_view_rsclient,
10326 show_ip_bgp_view_rsclient_cmd,
10327 "show ip bgp view WORD rsclient (A.B.C.D|X:X::X:X)",
10328 SHOW_STR
10329 IP_STR
10330 BGP_STR
10331 "BGP view\n"
10332 "BGP view name\n"
10333 "Information about Route Server Client\n"
10334 NEIGHBOR_ADDR_STR)
10335{
10336 struct bgp_table *table;
10337 struct peer *peer;
10338
10339 if (argc == 2)
10340 peer = peer_lookup_in_view (vty, argv[0], argv[1]);
10341 else
10342 peer = peer_lookup_in_view (vty, NULL, argv[0]);
10343
10344 if (! peer)
10345 return CMD_WARNING;
10346
10347 if (! peer->afc[AFI_IP][SAFI_UNICAST])
10348 {
10349 vty_out (vty, "%% Activate the neighbor for the address family first%s",
10350 VTY_NEWLINE);
10351 return CMD_WARNING;
10352 }
10353
10354 if ( ! CHECK_FLAG (peer->af_flags[AFI_IP][SAFI_UNICAST],
10355 PEER_FLAG_RSERVER_CLIENT))
10356 {
10357 vty_out (vty, "%% Neighbor is not a Route-Server client%s",
10358 VTY_NEWLINE);
10359 return CMD_WARNING;
10360 }
10361
10362 table = peer->rib[AFI_IP][SAFI_UNICAST];
10363
5a646650 10364 return bgp_show_table (vty, table, &peer->remote_id, bgp_show_type_normal, NULL);
fee0f4c6 10365}
10366
10367ALIAS (show_ip_bgp_view_rsclient,
10368 show_ip_bgp_rsclient_cmd,
10369 "show ip bgp rsclient (A.B.C.D|X:X::X:X)",
10370 SHOW_STR
10371 IP_STR
10372 BGP_STR
10373 "Information about Route Server Client\n"
10374 NEIGHBOR_ADDR_STR)
10375
10376DEFUN (show_ip_bgp_view_rsclient_route,
10377 show_ip_bgp_view_rsclient_route_cmd,
a8bf6f52 10378 "show ip bgp view WORD rsclient (A.B.C.D|X:X::X:X) A.B.C.D",
fee0f4c6 10379 SHOW_STR
10380 IP_STR
10381 BGP_STR
10382 "BGP view\n"
10383 "BGP view name\n"
10384 "Information about Route Server Client\n"
10385 NEIGHBOR_ADDR_STR
10386 "Network in the BGP routing table to display\n")
10387{
10388 struct bgp *bgp;
10389 struct peer *peer;
10390
10391 /* BGP structure lookup. */
10392 if (argc == 3)
10393 {
10394 bgp = bgp_lookup_by_name (argv[0]);
10395 if (bgp == NULL)
10396 {
10397 vty_out (vty, "Can't find BGP view %s%s", argv[0], VTY_NEWLINE);
10398 return CMD_WARNING;
10399 }
10400 }
10401 else
10402 {
10403 bgp = bgp_get_default ();
10404 if (bgp == NULL)
10405 {
10406 vty_out (vty, "No BGP process is configured%s", VTY_NEWLINE);
10407 return CMD_WARNING;
10408 }
10409 }
10410
10411 if (argc == 3)
10412 peer = peer_lookup_in_view (vty, argv[0], argv[1]);
10413 else
10414 peer = peer_lookup_in_view (vty, NULL, argv[0]);
10415
10416 if (! peer)
10417 return CMD_WARNING;
10418
10419 if (! peer->afc[AFI_IP][SAFI_UNICAST])
10420 {
10421 vty_out (vty, "%% Activate the neighbor for the address family first%s",
10422 VTY_NEWLINE);
10423 return CMD_WARNING;
10424}
10425
10426 if ( ! CHECK_FLAG (peer->af_flags[AFI_IP][SAFI_UNICAST],
10427 PEER_FLAG_RSERVER_CLIENT))
10428 {
10429 vty_out (vty, "%% Neighbor is not a Route-Server client%s",
10430 VTY_NEWLINE);
10431 return CMD_WARNING;
10432 }
10433
10434 return bgp_show_route_in_table (vty, bgp, peer->rib[AFI_IP][SAFI_UNICAST],
10435 (argc == 3) ? argv[2] : argv[1],
10436 AFI_IP, SAFI_UNICAST, NULL, 0);
10437}
10438
10439ALIAS (show_ip_bgp_view_rsclient_route,
10440 show_ip_bgp_rsclient_route_cmd,
10441 "show ip bgp rsclient (A.B.C.D|X:X::X:X) A.B.C.D",
10442 SHOW_STR
10443 IP_STR
10444 BGP_STR
10445 "Information about Route Server Client\n"
10446 NEIGHBOR_ADDR_STR
10447 "Network in the BGP routing table to display\n")
10448
10449DEFUN (show_ip_bgp_view_rsclient_prefix,
10450 show_ip_bgp_view_rsclient_prefix_cmd,
10451 "show ip bgp view WORD rsclient (A.B.C.D|X:X::X:X) A.B.C.D/M",
10452 SHOW_STR
10453 IP_STR
10454 BGP_STR
10455 "BGP view\n"
10456 "BGP view name\n"
10457 "Information about Route Server Client\n"
10458 NEIGHBOR_ADDR_STR
10459 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n")
10460{
10461 struct bgp *bgp;
10462 struct peer *peer;
10463
10464 /* BGP structure lookup. */
10465 if (argc == 3)
10466 {
10467 bgp = bgp_lookup_by_name (argv[0]);
10468 if (bgp == NULL)
10469 {
10470 vty_out (vty, "Can't find BGP view %s%s", argv[0], VTY_NEWLINE);
10471 return CMD_WARNING;
10472 }
10473 }
10474 else
10475 {
10476 bgp = bgp_get_default ();
10477 if (bgp == NULL)
10478 {
10479 vty_out (vty, "No BGP process is configured%s", VTY_NEWLINE);
10480 return CMD_WARNING;
10481 }
10482 }
10483
10484 if (argc == 3)
10485 peer = peer_lookup_in_view (vty, argv[0], argv[1]);
10486 else
10487 peer = peer_lookup_in_view (vty, NULL, argv[0]);
10488
10489 if (! peer)
10490 return CMD_WARNING;
10491
10492 if (! peer->afc[AFI_IP][SAFI_UNICAST])
10493 {
10494 vty_out (vty, "%% Activate the neighbor for the address family first%s",
10495 VTY_NEWLINE);
10496 return CMD_WARNING;
10497}
10498
10499 if ( ! CHECK_FLAG (peer->af_flags[AFI_IP][SAFI_UNICAST],
10500 PEER_FLAG_RSERVER_CLIENT))
10501{
10502 vty_out (vty, "%% Neighbor is not a Route-Server client%s",
10503 VTY_NEWLINE);
10504 return CMD_WARNING;
10505 }
10506
10507 return bgp_show_route_in_table (vty, bgp, peer->rib[AFI_IP][SAFI_UNICAST],
10508 (argc == 3) ? argv[2] : argv[1],
10509 AFI_IP, SAFI_UNICAST, NULL, 1);
10510}
10511
10512ALIAS (show_ip_bgp_view_rsclient_prefix,
10513 show_ip_bgp_rsclient_prefix_cmd,
10514 "show ip bgp rsclient (A.B.C.D|X:X::X:X) A.B.C.D/M",
10515 SHOW_STR
10516 IP_STR
10517 BGP_STR
10518 "Information about Route Server Client\n"
10519 NEIGHBOR_ADDR_STR
10520 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n")
10521
10522
718e3744 10523#ifdef HAVE_IPV6
bb46e94f 10524DEFUN (show_bgp_view_neighbor_routes,
10525 show_bgp_view_neighbor_routes_cmd,
10526 "show bgp view WORD neighbors (A.B.C.D|X:X::X:X) routes",
718e3744 10527 SHOW_STR
10528 BGP_STR
bb46e94f 10529 "BGP view\n"
10530 "BGP view name\n"
718e3744 10531 "Detailed information on TCP and BGP neighbor connections\n"
10532 "Neighbor to display information about\n"
10533 "Neighbor to display information about\n"
10534 "Display routes learned from neighbor\n")
10535{
bb46e94f 10536 struct peer *peer;
10537
10538 if (argc == 2)
10539 peer = peer_lookup_in_view (vty, argv[0], argv[1]);
10540 else
10541 peer = peer_lookup_in_view (vty, NULL, argv[0]);
10542
10543 if (! peer)
10544 return CMD_WARNING;
10545
10546 return bgp_show_neighbor_route (vty, peer, AFI_IP6, SAFI_UNICAST,
718e3744 10547 bgp_show_type_neighbor);
10548}
10549
bb46e94f 10550ALIAS (show_bgp_view_neighbor_routes,
10551 show_bgp_view_ipv6_neighbor_routes_cmd,
10552 "show bgp view WORD ipv6 neighbors (A.B.C.D|X:X::X:X) routes",
10553 SHOW_STR
10554 BGP_STR
10555 "BGP view\n"
10556 "BGP view name\n"
10557 "Address family\n"
10558 "Detailed information on TCP and BGP neighbor connections\n"
10559 "Neighbor to display information about\n"
10560 "Neighbor to display information about\n"
10561 "Display routes learned from neighbor\n")
10562
10563DEFUN (show_bgp_view_neighbor_damp,
10564 show_bgp_view_neighbor_damp_cmd,
10565 "show bgp view WORD neighbors (A.B.C.D|X:X::X:X) dampened-routes",
10566 SHOW_STR
10567 BGP_STR
10568 "BGP view\n"
10569 "BGP view name\n"
10570 "Detailed information on TCP and BGP neighbor connections\n"
10571 "Neighbor to display information about\n"
10572 "Neighbor to display information about\n"
10573 "Display the dampened routes received from neighbor\n")
10574{
10575 struct peer *peer;
10576
10577 if (argc == 2)
10578 peer = peer_lookup_in_view (vty, argv[0], argv[1]);
10579 else
10580 peer = peer_lookup_in_view (vty, NULL, argv[0]);
10581
10582 if (! peer)
10583 return CMD_WARNING;
10584
10585 return bgp_show_neighbor_route (vty, peer, AFI_IP6, SAFI_UNICAST,
10586 bgp_show_type_damp_neighbor);
10587}
10588
10589ALIAS (show_bgp_view_neighbor_damp,
10590 show_bgp_view_ipv6_neighbor_damp_cmd,
10591 "show bgp view WORD ipv6 neighbors (A.B.C.D|X:X::X:X) dampened-routes",
10592 SHOW_STR
10593 BGP_STR
10594 "BGP view\n"
10595 "BGP view name\n"
10596 "Address family\n"
10597 "Detailed information on TCP and BGP neighbor connections\n"
10598 "Neighbor to display information about\n"
10599 "Neighbor to display information about\n"
10600 "Display the dampened routes received from neighbor\n")
10601
10602DEFUN (show_bgp_view_neighbor_flap,
10603 show_bgp_view_neighbor_flap_cmd,
10604 "show bgp view WORD neighbors (A.B.C.D|X:X::X:X) flap-statistics",
10605 SHOW_STR
10606 BGP_STR
10607 "BGP view\n"
10608 "BGP view name\n"
10609 "Detailed information on TCP and BGP neighbor connections\n"
10610 "Neighbor to display information about\n"
10611 "Neighbor to display information about\n"
10612 "Display flap statistics of the routes learned from neighbor\n")
10613{
10614 struct peer *peer;
10615
10616 if (argc == 2)
10617 peer = peer_lookup_in_view (vty, argv[0], argv[1]);
10618 else
10619 peer = peer_lookup_in_view (vty, NULL, argv[0]);
10620
10621 if (! peer)
10622 return CMD_WARNING;
10623
10624 return bgp_show_neighbor_route (vty, peer, AFI_IP6, SAFI_UNICAST,
10625 bgp_show_type_flap_neighbor);
10626}
10627
10628ALIAS (show_bgp_view_neighbor_flap,
10629 show_bgp_view_ipv6_neighbor_flap_cmd,
10630 "show bgp view WORD ipv6 neighbors (A.B.C.D|X:X::X:X) flap-statistics",
10631 SHOW_STR
10632 BGP_STR
10633 "BGP view\n"
10634 "BGP view name\n"
10635 "Address family\n"
10636 "Detailed information on TCP and BGP neighbor connections\n"
10637 "Neighbor to display information about\n"
10638 "Neighbor to display information about\n"
10639 "Display flap statistics of the routes learned from neighbor\n")
10640
10641ALIAS (show_bgp_view_neighbor_routes,
10642 show_bgp_neighbor_routes_cmd,
10643 "show bgp neighbors (A.B.C.D|X:X::X:X) routes",
10644 SHOW_STR
10645 BGP_STR
10646 "Detailed information on TCP and BGP neighbor connections\n"
10647 "Neighbor to display information about\n"
10648 "Neighbor to display information about\n"
10649 "Display routes learned from neighbor\n")
10650
10651
10652ALIAS (show_bgp_view_neighbor_routes,
718e3744 10653 show_bgp_ipv6_neighbor_routes_cmd,
10654 "show bgp ipv6 neighbors (A.B.C.D|X:X::X:X) routes",
10655 SHOW_STR
10656 BGP_STR
10657 "Address family\n"
10658 "Detailed information on TCP and BGP neighbor connections\n"
10659 "Neighbor to display information about\n"
10660 "Neighbor to display information about\n"
10661 "Display routes learned from neighbor\n")
10662
10663/* old command */
bb46e94f 10664ALIAS (show_bgp_view_neighbor_routes,
718e3744 10665 ipv6_bgp_neighbor_routes_cmd,
10666 "show ipv6 bgp neighbors (A.B.C.D|X:X::X:X) routes",
10667 SHOW_STR
10668 IPV6_STR
10669 BGP_STR
10670 "Detailed information on TCP and BGP neighbor connections\n"
10671 "Neighbor to display information about\n"
10672 "Neighbor to display information about\n"
10673 "Display routes learned from neighbor\n")
718e3744 10674
10675/* old command */
10676DEFUN (ipv6_mbgp_neighbor_routes,
10677 ipv6_mbgp_neighbor_routes_cmd,
10678 "show ipv6 mbgp neighbors (A.B.C.D|X:X::X:X) routes",
10679 SHOW_STR
10680 IPV6_STR
10681 MBGP_STR
10682 "Detailed information on TCP and BGP neighbor connections\n"
10683 "Neighbor to display information about\n"
10684 "Neighbor to display information about\n"
10685 "Display routes learned from neighbor\n")
10686{
bb46e94f 10687 struct peer *peer;
10688
10689 peer = peer_lookup_in_view (vty, NULL, argv[0]);
10690 if (! peer)
10691 return CMD_WARNING;
10692
10693 return bgp_show_neighbor_route (vty, peer, AFI_IP6, SAFI_MULTICAST,
718e3744 10694 bgp_show_type_neighbor);
10695}
bb46e94f 10696
10697ALIAS (show_bgp_view_neighbor_flap,
10698 show_bgp_neighbor_flap_cmd,
10699 "show bgp neighbors (A.B.C.D|X:X::X:X) flap-statistics",
10700 SHOW_STR
10701 BGP_STR
10702 "Detailed information on TCP and BGP neighbor connections\n"
10703 "Neighbor to display information about\n"
10704 "Neighbor to display information about\n"
10705 "Display flap statistics of the routes learned from neighbor\n")
10706
10707ALIAS (show_bgp_view_neighbor_flap,
10708 show_bgp_ipv6_neighbor_flap_cmd,
10709 "show bgp ipv6 neighbors (A.B.C.D|X:X::X:X) flap-statistics",
10710 SHOW_STR
10711 BGP_STR
10712 "Address family\n"
10713 "Detailed information on TCP and BGP neighbor connections\n"
10714 "Neighbor to display information about\n"
10715 "Neighbor to display information about\n"
10716 "Display flap statistics of the routes learned from neighbor\n")
10717
10718ALIAS (show_bgp_view_neighbor_damp,
10719 show_bgp_neighbor_damp_cmd,
10720 "show bgp neighbors (A.B.C.D|X:X::X:X) dampened-routes",
10721 SHOW_STR
10722 BGP_STR
10723 "Detailed information on TCP and BGP neighbor connections\n"
10724 "Neighbor to display information about\n"
10725 "Neighbor to display information about\n"
10726 "Display the dampened routes received from neighbor\n")
10727
10728ALIAS (show_bgp_view_neighbor_damp,
10729 show_bgp_ipv6_neighbor_damp_cmd,
10730 "show bgp ipv6 neighbors (A.B.C.D|X:X::X:X) dampened-routes",
10731 SHOW_STR
10732 BGP_STR
10733 "Address family\n"
10734 "Detailed information on TCP and BGP neighbor connections\n"
10735 "Neighbor to display information about\n"
10736 "Neighbor to display information about\n"
c001ae62 10737 "Display the dampened routes received from neighbor\n")
fee0f4c6 10738
10739DEFUN (show_bgp_view_rsclient,
10740 show_bgp_view_rsclient_cmd,
10741 "show bgp view WORD rsclient (A.B.C.D|X:X::X:X)",
10742 SHOW_STR
10743 BGP_STR
10744 "BGP view\n"
10745 "BGP view name\n"
10746 "Information about Route Server Client\n"
10747 NEIGHBOR_ADDR_STR)
10748{
10749 struct bgp_table *table;
10750 struct peer *peer;
10751
10752 if (argc == 2)
10753 peer = peer_lookup_in_view (vty, argv[0], argv[1]);
10754 else
10755 peer = peer_lookup_in_view (vty, NULL, argv[0]);
10756
10757 if (! peer)
10758 return CMD_WARNING;
10759
10760 if (! peer->afc[AFI_IP6][SAFI_UNICAST])
10761 {
10762 vty_out (vty, "%% Activate the neighbor for the address family first%s",
10763 VTY_NEWLINE);
10764 return CMD_WARNING;
10765 }
10766
10767 if ( ! CHECK_FLAG (peer->af_flags[AFI_IP6][SAFI_UNICAST],
10768 PEER_FLAG_RSERVER_CLIENT))
10769 {
10770 vty_out (vty, "%% Neighbor is not a Route-Server client%s",
10771 VTY_NEWLINE);
10772 return CMD_WARNING;
10773 }
10774
10775 table = peer->rib[AFI_IP6][SAFI_UNICAST];
10776
5a646650 10777 return bgp_show_table (vty, table, &peer->remote_id, bgp_show_type_normal, NULL);
fee0f4c6 10778}
10779
10780ALIAS (show_bgp_view_rsclient,
10781 show_bgp_rsclient_cmd,
10782 "show bgp rsclient (A.B.C.D|X:X::X:X)",
10783 SHOW_STR
10784 BGP_STR
10785 "Information about Route Server Client\n"
10786 NEIGHBOR_ADDR_STR)
10787
10788DEFUN (show_bgp_view_rsclient_route,
10789 show_bgp_view_rsclient_route_cmd,
10790 "show bgp view WORD rsclient (A.B.C.D|X:X::X:X) X:X::X:X",
10791 SHOW_STR
10792 BGP_STR
10793 "BGP view\n"
10794 "BGP view name\n"
10795 "Information about Route Server Client\n"
10796 NEIGHBOR_ADDR_STR
10797 "Network in the BGP routing table to display\n")
10798{
10799 struct bgp *bgp;
10800 struct peer *peer;
10801
10802 /* BGP structure lookup. */
10803 if (argc == 3)
10804 {
10805 bgp = bgp_lookup_by_name (argv[0]);
10806 if (bgp == NULL)
10807 {
10808 vty_out (vty, "Can't find BGP view %s%s", argv[0], VTY_NEWLINE);
10809 return CMD_WARNING;
10810 }
10811 }
10812 else
10813 {
10814 bgp = bgp_get_default ();
10815 if (bgp == NULL)
10816 {
10817 vty_out (vty, "No BGP process is configured%s", VTY_NEWLINE);
10818 return CMD_WARNING;
10819 }
10820 }
10821
10822 if (argc == 3)
10823 peer = peer_lookup_in_view (vty, argv[0], argv[1]);
10824 else
10825 peer = peer_lookup_in_view (vty, NULL, argv[0]);
10826
10827 if (! peer)
10828 return CMD_WARNING;
10829
10830 if (! peer->afc[AFI_IP6][SAFI_UNICAST])
10831 {
10832 vty_out (vty, "%% Activate the neighbor for the address family first%s",
10833 VTY_NEWLINE);
10834 return CMD_WARNING;
10835 }
10836
10837 if ( ! CHECK_FLAG (peer->af_flags[AFI_IP6][SAFI_UNICAST],
10838 PEER_FLAG_RSERVER_CLIENT))
10839 {
10840 vty_out (vty, "%% Neighbor is not a Route-Server client%s",
10841 VTY_NEWLINE);
10842 return CMD_WARNING;
10843 }
10844
10845 return bgp_show_route_in_table (vty, bgp, peer->rib[AFI_IP6][SAFI_UNICAST],
10846 (argc == 3) ? argv[2] : argv[1],
10847 AFI_IP6, SAFI_UNICAST, NULL, 0);
10848}
10849
10850ALIAS (show_bgp_view_rsclient_route,
10851 show_bgp_rsclient_route_cmd,
10852 "show bgp rsclient (A.B.C.D|X:X::X:X) X:X::X:X",
10853 SHOW_STR
10854 BGP_STR
10855 "Information about Route Server Client\n"
10856 NEIGHBOR_ADDR_STR
10857 "Network in the BGP routing table to display\n")
10858
10859DEFUN (show_bgp_view_rsclient_prefix,
10860 show_bgp_view_rsclient_prefix_cmd,
10861 "show bgp view WORD rsclient (A.B.C.D|X:X::X:X) X:X::X:X/M",
10862 SHOW_STR
10863 BGP_STR
10864 "BGP view\n"
10865 "BGP view name\n"
10866 "Information about Route Server Client\n"
10867 NEIGHBOR_ADDR_STR
10868 "IPv6 prefix <network>/<length>, e.g., 3ffe::/16\n")
10869{
10870 struct bgp *bgp;
10871 struct peer *peer;
10872
10873 /* BGP structure lookup. */
10874 if (argc == 3)
10875 {
10876 bgp = bgp_lookup_by_name (argv[0]);
10877 if (bgp == NULL)
10878 {
10879 vty_out (vty, "Can't find BGP view %s%s", argv[0], VTY_NEWLINE);
10880 return CMD_WARNING;
10881 }
10882 }
10883 else
10884 {
10885 bgp = bgp_get_default ();
10886 if (bgp == NULL)
10887 {
10888 vty_out (vty, "No BGP process is configured%s", VTY_NEWLINE);
10889 return CMD_WARNING;
10890 }
10891 }
10892
10893 if (argc == 3)
10894 peer = peer_lookup_in_view (vty, argv[0], argv[1]);
10895 else
10896 peer = peer_lookup_in_view (vty, NULL, argv[0]);
10897
10898 if (! peer)
10899 return CMD_WARNING;
10900
10901 if (! peer->afc[AFI_IP6][SAFI_UNICAST])
10902 {
10903 vty_out (vty, "%% Activate the neighbor for the address family first%s",
10904 VTY_NEWLINE);
10905 return CMD_WARNING;
10906 }
10907
10908 if ( ! CHECK_FLAG (peer->af_flags[AFI_IP6][SAFI_UNICAST],
10909 PEER_FLAG_RSERVER_CLIENT))
10910 {
10911 vty_out (vty, "%% Neighbor is not a Route-Server client%s",
10912 VTY_NEWLINE);
10913 return CMD_WARNING;
10914 }
10915
10916 return bgp_show_route_in_table (vty, bgp, peer->rib[AFI_IP6][SAFI_UNICAST],
10917 (argc == 3) ? argv[2] : argv[1],
10918 AFI_IP6, SAFI_UNICAST, NULL, 1);
10919}
10920
10921ALIAS (show_bgp_view_rsclient_prefix,
10922 show_bgp_rsclient_prefix_cmd,
10923 "show bgp rsclient (A.B.C.D|X:X::X:X) X:X::X:X/M",
10924 SHOW_STR
10925 BGP_STR
10926 "Information about Route Server Client\n"
10927 NEIGHBOR_ADDR_STR
10928 "IPv6 prefix <network>/<length>, e.g., 3ffe::/16\n")
10929
718e3744 10930#endif /* HAVE_IPV6 */
10931\f
10932struct bgp_table *bgp_distance_table;
10933
10934struct bgp_distance
10935{
10936 /* Distance value for the IP source prefix. */
10937 u_char distance;
10938
10939 /* Name of the access-list to be matched. */
10940 char *access_list;
10941};
10942
94f2b392 10943static struct bgp_distance *
66e5cd87 10944bgp_distance_new (void)
718e3744 10945{
393deb9b 10946 return XCALLOC (MTYPE_BGP_DISTANCE, sizeof (struct bgp_distance));
718e3744 10947}
10948
94f2b392 10949static void
718e3744 10950bgp_distance_free (struct bgp_distance *bdistance)
10951{
10952 XFREE (MTYPE_BGP_DISTANCE, bdistance);
10953}
10954
94f2b392 10955static int
fd79ac91 10956bgp_distance_set (struct vty *vty, const char *distance_str,
10957 const char *ip_str, const char *access_list_str)
718e3744 10958{
10959 int ret;
10960 struct prefix_ipv4 p;
10961 u_char distance;
10962 struct bgp_node *rn;
10963 struct bgp_distance *bdistance;
10964
10965 ret = str2prefix_ipv4 (ip_str, &p);
10966 if (ret == 0)
10967 {
10968 vty_out (vty, "Malformed prefix%s", VTY_NEWLINE);
10969 return CMD_WARNING;
10970 }
10971
10972 distance = atoi (distance_str);
10973
10974 /* Get BGP distance node. */
10975 rn = bgp_node_get (bgp_distance_table, (struct prefix *) &p);
10976 if (rn->info)
10977 {
10978 bdistance = rn->info;
10979 bgp_unlock_node (rn);
10980 }
10981 else
10982 {
10983 bdistance = bgp_distance_new ();
10984 rn->info = bdistance;
10985 }
10986
10987 /* Set distance value. */
10988 bdistance->distance = distance;
10989
10990 /* Reset access-list configuration. */
10991 if (bdistance->access_list)
10992 {
10993 free (bdistance->access_list);
10994 bdistance->access_list = NULL;
10995 }
10996 if (access_list_str)
10997 bdistance->access_list = strdup (access_list_str);
10998
10999 return CMD_SUCCESS;
11000}
11001
94f2b392 11002static int
fd79ac91 11003bgp_distance_unset (struct vty *vty, const char *distance_str,
11004 const char *ip_str, const char *access_list_str)
718e3744 11005{
11006 int ret;
11007 struct prefix_ipv4 p;
11008 u_char distance;
11009 struct bgp_node *rn;
11010 struct bgp_distance *bdistance;
11011
11012 ret = str2prefix_ipv4 (ip_str, &p);
11013 if (ret == 0)
11014 {
11015 vty_out (vty, "Malformed prefix%s", VTY_NEWLINE);
11016 return CMD_WARNING;
11017 }
11018
11019 distance = atoi (distance_str);
11020
11021 rn = bgp_node_lookup (bgp_distance_table, (struct prefix *)&p);
11022 if (! rn)
11023 {
11024 vty_out (vty, "Can't find specified prefix%s", VTY_NEWLINE);
11025 return CMD_WARNING;
11026 }
11027
11028 bdistance = rn->info;
11029
11030 if (bdistance->access_list)
11031 free (bdistance->access_list);
11032 bgp_distance_free (bdistance);
11033
11034 rn->info = NULL;
11035 bgp_unlock_node (rn);
11036 bgp_unlock_node (rn);
11037
11038 return CMD_SUCCESS;
11039}
11040
718e3744 11041/* Apply BGP information to distance method. */
11042u_char
11043bgp_distance_apply (struct prefix *p, struct bgp_info *rinfo, struct bgp *bgp)
11044{
11045 struct bgp_node *rn;
11046 struct prefix_ipv4 q;
11047 struct peer *peer;
11048 struct bgp_distance *bdistance;
11049 struct access_list *alist;
11050 struct bgp_static *bgp_static;
11051
11052 if (! bgp)
11053 return 0;
11054
11055 if (p->family != AF_INET)
11056 return 0;
11057
11058 peer = rinfo->peer;
11059
11060 if (peer->su.sa.sa_family != AF_INET)
11061 return 0;
11062
11063 memset (&q, 0, sizeof (struct prefix_ipv4));
11064 q.family = AF_INET;
11065 q.prefix = peer->su.sin.sin_addr;
11066 q.prefixlen = IPV4_MAX_BITLEN;
11067
11068 /* Check source address. */
11069 rn = bgp_node_match (bgp_distance_table, (struct prefix *) &q);
11070 if (rn)
11071 {
11072 bdistance = rn->info;
11073 bgp_unlock_node (rn);
11074
11075 if (bdistance->access_list)
11076 {
11077 alist = access_list_lookup (AFI_IP, bdistance->access_list);
11078 if (alist && access_list_apply (alist, p) == FILTER_PERMIT)
11079 return bdistance->distance;
11080 }
11081 else
11082 return bdistance->distance;
11083 }
11084
11085 /* Backdoor check. */
11086 rn = bgp_node_lookup (bgp->route[AFI_IP][SAFI_UNICAST], p);
11087 if (rn)
11088 {
11089 bgp_static = rn->info;
11090 bgp_unlock_node (rn);
11091
11092 if (bgp_static->backdoor)
11093 {
11094 if (bgp->distance_local)
11095 return bgp->distance_local;
11096 else
11097 return ZEBRA_IBGP_DISTANCE_DEFAULT;
11098 }
11099 }
11100
11101 if (peer_sort (peer) == BGP_PEER_EBGP)
11102 {
11103 if (bgp->distance_ebgp)
11104 return bgp->distance_ebgp;
11105 return ZEBRA_EBGP_DISTANCE_DEFAULT;
11106 }
11107 else
11108 {
11109 if (bgp->distance_ibgp)
11110 return bgp->distance_ibgp;
11111 return ZEBRA_IBGP_DISTANCE_DEFAULT;
11112 }
11113}
11114
11115DEFUN (bgp_distance,
11116 bgp_distance_cmd,
11117 "distance bgp <1-255> <1-255> <1-255>",
11118 "Define an administrative distance\n"
11119 "BGP distance\n"
11120 "Distance for routes external to the AS\n"
11121 "Distance for routes internal to the AS\n"
11122 "Distance for local routes\n")
11123{
11124 struct bgp *bgp;
11125
11126 bgp = vty->index;
11127
11128 bgp->distance_ebgp = atoi (argv[0]);
11129 bgp->distance_ibgp = atoi (argv[1]);
11130 bgp->distance_local = atoi (argv[2]);
11131 return CMD_SUCCESS;
11132}
11133
11134DEFUN (no_bgp_distance,
11135 no_bgp_distance_cmd,
11136 "no distance bgp <1-255> <1-255> <1-255>",
11137 NO_STR
11138 "Define an administrative distance\n"
11139 "BGP distance\n"
11140 "Distance for routes external to the AS\n"
11141 "Distance for routes internal to the AS\n"
11142 "Distance for local routes\n")
11143{
11144 struct bgp *bgp;
11145
11146 bgp = vty->index;
11147
11148 bgp->distance_ebgp= 0;
11149 bgp->distance_ibgp = 0;
11150 bgp->distance_local = 0;
11151 return CMD_SUCCESS;
11152}
11153
11154ALIAS (no_bgp_distance,
11155 no_bgp_distance2_cmd,
11156 "no distance bgp",
11157 NO_STR
11158 "Define an administrative distance\n"
11159 "BGP distance\n")
11160
11161DEFUN (bgp_distance_source,
11162 bgp_distance_source_cmd,
11163 "distance <1-255> A.B.C.D/M",
11164 "Define an administrative distance\n"
11165 "Administrative distance\n"
11166 "IP source prefix\n")
11167{
11168 bgp_distance_set (vty, argv[0], argv[1], NULL);
11169 return CMD_SUCCESS;
11170}
11171
11172DEFUN (no_bgp_distance_source,
11173 no_bgp_distance_source_cmd,
11174 "no distance <1-255> A.B.C.D/M",
11175 NO_STR
11176 "Define an administrative distance\n"
11177 "Administrative distance\n"
11178 "IP source prefix\n")
11179{
11180 bgp_distance_unset (vty, argv[0], argv[1], NULL);
11181 return CMD_SUCCESS;
11182}
11183
11184DEFUN (bgp_distance_source_access_list,
11185 bgp_distance_source_access_list_cmd,
11186 "distance <1-255> A.B.C.D/M WORD",
11187 "Define an administrative distance\n"
11188 "Administrative distance\n"
11189 "IP source prefix\n"
11190 "Access list name\n")
11191{
11192 bgp_distance_set (vty, argv[0], argv[1], argv[2]);
11193 return CMD_SUCCESS;
11194}
11195
11196DEFUN (no_bgp_distance_source_access_list,
11197 no_bgp_distance_source_access_list_cmd,
11198 "no distance <1-255> A.B.C.D/M WORD",
11199 NO_STR
11200 "Define an administrative distance\n"
11201 "Administrative distance\n"
11202 "IP source prefix\n"
11203 "Access list name\n")
11204{
11205 bgp_distance_unset (vty, argv[0], argv[1], argv[2]);
11206 return CMD_SUCCESS;
11207}
11208\f
11209DEFUN (bgp_damp_set,
11210 bgp_damp_set_cmd,
11211 "bgp dampening <1-45> <1-20000> <1-20000> <1-255>",
11212 "BGP Specific commands\n"
11213 "Enable route-flap dampening\n"
11214 "Half-life time for the penalty\n"
11215 "Value to start reusing a route\n"
11216 "Value to start suppressing a route\n"
11217 "Maximum duration to suppress a stable route\n")
11218{
11219 struct bgp *bgp;
11220 int half = DEFAULT_HALF_LIFE * 60;
11221 int reuse = DEFAULT_REUSE;
11222 int suppress = DEFAULT_SUPPRESS;
11223 int max = 4 * half;
11224
11225 if (argc == 4)
11226 {
11227 half = atoi (argv[0]) * 60;
11228 reuse = atoi (argv[1]);
11229 suppress = atoi (argv[2]);
11230 max = atoi (argv[3]) * 60;
11231 }
11232 else if (argc == 1)
11233 {
11234 half = atoi (argv[0]) * 60;
11235 max = 4 * half;
11236 }
11237
11238 bgp = vty->index;
11239 return bgp_damp_enable (bgp, bgp_node_afi (vty), bgp_node_safi (vty),
11240 half, reuse, suppress, max);
11241}
11242
11243ALIAS (bgp_damp_set,
11244 bgp_damp_set2_cmd,
11245 "bgp dampening <1-45>",
11246 "BGP Specific commands\n"
11247 "Enable route-flap dampening\n"
11248 "Half-life time for the penalty\n")
11249
11250ALIAS (bgp_damp_set,
11251 bgp_damp_set3_cmd,
11252 "bgp dampening",
11253 "BGP Specific commands\n"
11254 "Enable route-flap dampening\n")
11255
11256DEFUN (bgp_damp_unset,
11257 bgp_damp_unset_cmd,
11258 "no bgp dampening",
11259 NO_STR
11260 "BGP Specific commands\n"
11261 "Enable route-flap dampening\n")
11262{
11263 struct bgp *bgp;
11264
11265 bgp = vty->index;
11266 return bgp_damp_disable (bgp, bgp_node_afi (vty), bgp_node_safi (vty));
11267}
11268
11269ALIAS (bgp_damp_unset,
11270 bgp_damp_unset2_cmd,
11271 "no bgp dampening <1-45> <1-20000> <1-20000> <1-255>",
11272 NO_STR
11273 "BGP Specific commands\n"
11274 "Enable route-flap dampening\n"
11275 "Half-life time for the penalty\n"
11276 "Value to start reusing a route\n"
11277 "Value to start suppressing a route\n"
11278 "Maximum duration to suppress a stable route\n")
11279
11280DEFUN (show_ip_bgp_dampened_paths,
11281 show_ip_bgp_dampened_paths_cmd,
11282 "show ip bgp dampened-paths",
11283 SHOW_STR
11284 IP_STR
11285 BGP_STR
11286 "Display paths suppressed due to dampening\n")
11287{
5a646650 11288 return bgp_show (vty, NULL, AFI_IP, SAFI_UNICAST, bgp_show_type_dampend_paths,
11289 NULL);
718e3744 11290}
11291
11292DEFUN (show_ip_bgp_flap_statistics,
11293 show_ip_bgp_flap_statistics_cmd,
11294 "show ip bgp flap-statistics",
11295 SHOW_STR
11296 IP_STR
11297 BGP_STR
11298 "Display flap statistics of routes\n")
11299{
5a646650 11300 return bgp_show (vty, NULL, AFI_IP, SAFI_UNICAST,
11301 bgp_show_type_flap_statistics, NULL);
718e3744 11302}
11303\f
11304/* Display specified route of BGP table. */
94f2b392 11305static int
fd79ac91 11306bgp_clear_damp_route (struct vty *vty, const char *view_name,
11307 const char *ip_str, afi_t afi, safi_t safi,
11308 struct prefix_rd *prd, int prefix_check)
718e3744 11309{
11310 int ret;
11311 struct prefix match;
11312 struct bgp_node *rn;
11313 struct bgp_node *rm;
11314 struct bgp_info *ri;
11315 struct bgp_info *ri_temp;
11316 struct bgp *bgp;
11317 struct bgp_table *table;
11318
11319 /* BGP structure lookup. */
11320 if (view_name)
11321 {
11322 bgp = bgp_lookup_by_name (view_name);
11323 if (bgp == NULL)
11324 {
11325 vty_out (vty, "%% Can't find BGP view %s%s", view_name, VTY_NEWLINE);
11326 return CMD_WARNING;
11327 }
11328 }
11329 else
11330 {
11331 bgp = bgp_get_default ();
11332 if (bgp == NULL)
11333 {
11334 vty_out (vty, "%% No BGP process is configured%s", VTY_NEWLINE);
11335 return CMD_WARNING;
11336 }
11337 }
11338
11339 /* Check IP address argument. */
11340 ret = str2prefix (ip_str, &match);
11341 if (! ret)
11342 {
11343 vty_out (vty, "%% address is malformed%s", VTY_NEWLINE);
11344 return CMD_WARNING;
11345 }
11346
11347 match.family = afi2family (afi);
11348
11349 if (safi == SAFI_MPLS_VPN)
11350 {
11351 for (rn = bgp_table_top (bgp->rib[AFI_IP][SAFI_MPLS_VPN]); rn; rn = bgp_route_next (rn))
11352 {
11353 if (prd && memcmp (rn->p.u.val, prd->val, 8) != 0)
11354 continue;
11355
11356 if ((table = rn->info) != NULL)
11357 if ((rm = bgp_node_match (table, &match)) != NULL)
11358 if (! prefix_check || rm->p.prefixlen == match.prefixlen)
11359 {
11360 ri = rm->info;
11361 while (ri)
11362 {
fb982c25 11363 if (ri->extra && ri->extra->damp_info)
718e3744 11364 {
11365 ri_temp = ri->next;
fb982c25 11366 bgp_damp_info_free (ri->extra->damp_info, 1);
718e3744 11367 ri = ri_temp;
11368 }
11369 else
11370 ri = ri->next;
11371 }
11372 }
11373 }
11374 }
11375 else
11376 {
11377 if ((rn = bgp_node_match (bgp->rib[afi][safi], &match)) != NULL)
11378 if (! prefix_check || rn->p.prefixlen == match.prefixlen)
11379 {
11380 ri = rn->info;
11381 while (ri)
11382 {
fb982c25 11383 if (ri->extra && ri->extra->damp_info)
718e3744 11384 {
11385 ri_temp = ri->next;
fb982c25 11386 bgp_damp_info_free (ri->extra->damp_info, 1);
718e3744 11387 ri = ri_temp;
11388 }
11389 else
11390 ri = ri->next;
11391 }
11392 }
11393 }
11394
11395 return CMD_SUCCESS;
11396}
11397
11398DEFUN (clear_ip_bgp_dampening,
11399 clear_ip_bgp_dampening_cmd,
11400 "clear ip bgp dampening",
11401 CLEAR_STR
11402 IP_STR
11403 BGP_STR
11404 "Clear route flap dampening information\n")
11405{
11406 bgp_damp_info_clean ();
11407 return CMD_SUCCESS;
11408}
11409
11410DEFUN (clear_ip_bgp_dampening_prefix,
11411 clear_ip_bgp_dampening_prefix_cmd,
11412 "clear ip bgp dampening A.B.C.D/M",
11413 CLEAR_STR
11414 IP_STR
11415 BGP_STR
11416 "Clear route flap dampening information\n"
11417 "IP prefix <network>/<length>, e.g., 35.0.0.0/8\n")
11418{
11419 return bgp_clear_damp_route (vty, NULL, argv[0], AFI_IP,
11420 SAFI_UNICAST, NULL, 1);
11421}
11422
11423DEFUN (clear_ip_bgp_dampening_address,
11424 clear_ip_bgp_dampening_address_cmd,
11425 "clear ip bgp dampening A.B.C.D",
11426 CLEAR_STR
11427 IP_STR
11428 BGP_STR
11429 "Clear route flap dampening information\n"
11430 "Network to clear damping information\n")
11431{
11432 return bgp_clear_damp_route (vty, NULL, argv[0], AFI_IP,
11433 SAFI_UNICAST, NULL, 0);
11434}
11435
11436DEFUN (clear_ip_bgp_dampening_address_mask,
11437 clear_ip_bgp_dampening_address_mask_cmd,
11438 "clear ip bgp dampening A.B.C.D A.B.C.D",
11439 CLEAR_STR
11440 IP_STR
11441 BGP_STR
11442 "Clear route flap dampening information\n"
11443 "Network to clear damping information\n"
11444 "Network mask\n")
11445{
11446 int ret;
11447 char prefix_str[BUFSIZ];
11448
11449 ret = netmask_str2prefix_str (argv[0], argv[1], prefix_str);
11450 if (! ret)
11451 {
11452 vty_out (vty, "%% Inconsistent address and mask%s", VTY_NEWLINE);
11453 return CMD_WARNING;
11454 }
11455
11456 return bgp_clear_damp_route (vty, NULL, prefix_str, AFI_IP,
11457 SAFI_UNICAST, NULL, 0);
11458}
11459\f
94f2b392 11460static int
718e3744 11461bgp_config_write_network_vpnv4 (struct vty *vty, struct bgp *bgp,
11462 afi_t afi, safi_t safi, int *write)
11463{
11464 struct bgp_node *prn;
11465 struct bgp_node *rn;
11466 struct bgp_table *table;
11467 struct prefix *p;
11468 struct prefix_rd *prd;
11469 struct bgp_static *bgp_static;
11470 u_int32_t label;
11471 char buf[SU_ADDRSTRLEN];
11472 char rdbuf[RD_ADDRSTRLEN];
11473
11474 /* Network configuration. */
11475 for (prn = bgp_table_top (bgp->route[afi][safi]); prn; prn = bgp_route_next (prn))
11476 if ((table = prn->info) != NULL)
11477 for (rn = bgp_table_top (table); rn; rn = bgp_route_next (rn))
11478 if ((bgp_static = rn->info) != NULL)
11479 {
11480 p = &rn->p;
11481 prd = (struct prefix_rd *) &prn->p;
11482
11483 /* "address-family" display. */
11484 bgp_config_write_family_header (vty, afi, safi, write);
11485
11486 /* "network" configuration display. */
11487 prefix_rd2str (prd, rdbuf, RD_ADDRSTRLEN);
11488 label = decode_label (bgp_static->tag);
11489
11490 vty_out (vty, " network %s/%d rd %s tag %d",
11491 inet_ntop (p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
11492 p->prefixlen,
11493 rdbuf, label);
11494 vty_out (vty, "%s", VTY_NEWLINE);
11495 }
11496 return 0;
11497}
11498
11499/* Configuration of static route announcement and aggregate
11500 information. */
11501int
11502bgp_config_write_network (struct vty *vty, struct bgp *bgp,
11503 afi_t afi, safi_t safi, int *write)
11504{
11505 struct bgp_node *rn;
11506 struct prefix *p;
11507 struct bgp_static *bgp_static;
11508 struct bgp_aggregate *bgp_aggregate;
11509 char buf[SU_ADDRSTRLEN];
11510
11511 if (afi == AFI_IP && safi == SAFI_MPLS_VPN)
11512 return bgp_config_write_network_vpnv4 (vty, bgp, afi, safi, write);
11513
11514 /* Network configuration. */
11515 for (rn = bgp_table_top (bgp->route[afi][safi]); rn; rn = bgp_route_next (rn))
11516 if ((bgp_static = rn->info) != NULL)
11517 {
11518 p = &rn->p;
11519
11520 /* "address-family" display. */
11521 bgp_config_write_family_header (vty, afi, safi, write);
11522
11523 /* "network" configuration display. */
11524 if (bgp_option_check (BGP_OPT_CONFIG_CISCO) && afi == AFI_IP)
11525 {
11526 u_int32_t destination;
11527 struct in_addr netmask;
11528
11529 destination = ntohl (p->u.prefix4.s_addr);
11530 masklen2ip (p->prefixlen, &netmask);
11531 vty_out (vty, " network %s",
11532 inet_ntop (p->family, &p->u.prefix, buf, SU_ADDRSTRLEN));
11533
11534 if ((IN_CLASSC (destination) && p->prefixlen == 24)
11535 || (IN_CLASSB (destination) && p->prefixlen == 16)
11536 || (IN_CLASSA (destination) && p->prefixlen == 8)
11537 || p->u.prefix4.s_addr == 0)
11538 {
11539 /* Natural mask is not display. */
11540 }
11541 else
11542 vty_out (vty, " mask %s", inet_ntoa (netmask));
11543 }
11544 else
11545 {
11546 vty_out (vty, " network %s/%d",
11547 inet_ntop (p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
11548 p->prefixlen);
11549 }
11550
11551 if (bgp_static->rmap.name)
11552 vty_out (vty, " route-map %s", bgp_static->rmap.name);
41367172
PJ
11553 else
11554 {
11555 if (bgp_static->backdoor)
11556 vty_out (vty, " backdoor");
11557 if (bgp_static->ttl)
11558 vty_out (vty, " pathlimit %u", bgp_static->ttl);
11559 }
718e3744 11560
11561 vty_out (vty, "%s", VTY_NEWLINE);
11562 }
11563
11564 /* Aggregate-address configuration. */
11565 for (rn = bgp_table_top (bgp->aggregate[afi][safi]); rn; rn = bgp_route_next (rn))
11566 if ((bgp_aggregate = rn->info) != NULL)
11567 {
11568 p = &rn->p;
11569
11570 /* "address-family" display. */
11571 bgp_config_write_family_header (vty, afi, safi, write);
11572
11573 if (bgp_option_check (BGP_OPT_CONFIG_CISCO) && afi == AFI_IP)
11574 {
11575 struct in_addr netmask;
11576
11577 masklen2ip (p->prefixlen, &netmask);
11578 vty_out (vty, " aggregate-address %s %s",
11579 inet_ntop (p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
11580 inet_ntoa (netmask));
11581 }
11582 else
11583 {
11584 vty_out (vty, " aggregate-address %s/%d",
11585 inet_ntop (p->family, &p->u.prefix, buf, SU_ADDRSTRLEN),
11586 p->prefixlen);
11587 }
11588
11589 if (bgp_aggregate->as_set)
11590 vty_out (vty, " as-set");
11591
11592 if (bgp_aggregate->summary_only)
11593 vty_out (vty, " summary-only");
11594
11595 vty_out (vty, "%s", VTY_NEWLINE);
11596 }
11597
11598 return 0;
11599}
11600
11601int
11602bgp_config_write_distance (struct vty *vty, struct bgp *bgp)
11603{
11604 struct bgp_node *rn;
11605 struct bgp_distance *bdistance;
11606
11607 /* Distance configuration. */
11608 if (bgp->distance_ebgp
11609 && bgp->distance_ibgp
11610 && bgp->distance_local
11611 && (bgp->distance_ebgp != ZEBRA_EBGP_DISTANCE_DEFAULT
11612 || bgp->distance_ibgp != ZEBRA_IBGP_DISTANCE_DEFAULT
11613 || bgp->distance_local != ZEBRA_IBGP_DISTANCE_DEFAULT))
11614 vty_out (vty, " distance bgp %d %d %d%s",
11615 bgp->distance_ebgp, bgp->distance_ibgp, bgp->distance_local,
11616 VTY_NEWLINE);
11617
11618 for (rn = bgp_table_top (bgp_distance_table); rn; rn = bgp_route_next (rn))
11619 if ((bdistance = rn->info) != NULL)
11620 {
11621 vty_out (vty, " distance %d %s/%d %s%s", bdistance->distance,
11622 inet_ntoa (rn->p.u.prefix4), rn->p.prefixlen,
11623 bdistance->access_list ? bdistance->access_list : "",
11624 VTY_NEWLINE);
11625 }
11626
11627 return 0;
11628}
11629
11630/* Allocate routing table structure and install commands. */
11631void
66e5cd87 11632bgp_route_init (void)
718e3744 11633{
11634 /* Init BGP distance table. */
64e580a7 11635 bgp_distance_table = bgp_table_init (AFI_IP, SAFI_UNICAST);
718e3744 11636
11637 /* IPv4 BGP commands. */
11638 install_element (BGP_NODE, &bgp_network_cmd);
11639 install_element (BGP_NODE, &bgp_network_mask_cmd);
11640 install_element (BGP_NODE, &bgp_network_mask_natural_cmd);
11641 install_element (BGP_NODE, &bgp_network_route_map_cmd);
11642 install_element (BGP_NODE, &bgp_network_mask_route_map_cmd);
11643 install_element (BGP_NODE, &bgp_network_mask_natural_route_map_cmd);
11644 install_element (BGP_NODE, &bgp_network_backdoor_cmd);
11645 install_element (BGP_NODE, &bgp_network_mask_backdoor_cmd);
11646 install_element (BGP_NODE, &bgp_network_mask_natural_backdoor_cmd);
41367172
PJ
11647 install_element (BGP_NODE, &bgp_network_ttl_cmd);
11648 install_element (BGP_NODE, &bgp_network_mask_ttl_cmd);
11649 install_element (BGP_NODE, &bgp_network_mask_natural_ttl_cmd);
11650 install_element (BGP_NODE, &bgp_network_backdoor_ttl_cmd);
11651 install_element (BGP_NODE, &bgp_network_mask_backdoor_ttl_cmd);
11652 install_element (BGP_NODE, &bgp_network_mask_natural_backdoor_ttl_cmd);
718e3744 11653 install_element (BGP_NODE, &no_bgp_network_cmd);
11654 install_element (BGP_NODE, &no_bgp_network_mask_cmd);
11655 install_element (BGP_NODE, &no_bgp_network_mask_natural_cmd);
11656 install_element (BGP_NODE, &no_bgp_network_route_map_cmd);
11657 install_element (BGP_NODE, &no_bgp_network_mask_route_map_cmd);
11658 install_element (BGP_NODE, &no_bgp_network_mask_natural_route_map_cmd);
11659 install_element (BGP_NODE, &no_bgp_network_backdoor_cmd);
11660 install_element (BGP_NODE, &no_bgp_network_mask_backdoor_cmd);
11661 install_element (BGP_NODE, &no_bgp_network_mask_natural_backdoor_cmd);
41367172
PJ
11662 install_element (BGP_NODE, &no_bgp_network_ttl_cmd);
11663 install_element (BGP_NODE, &no_bgp_network_mask_ttl_cmd);
11664 install_element (BGP_NODE, &no_bgp_network_mask_natural_ttl_cmd);
11665 install_element (BGP_NODE, &no_bgp_network_backdoor_ttl_cmd);
11666 install_element (BGP_NODE, &no_bgp_network_mask_backdoor_ttl_cmd);
11667 install_element (BGP_NODE, &no_bgp_network_mask_natural_backdoor_ttl_cmd);
718e3744 11668
11669 install_element (BGP_NODE, &aggregate_address_cmd);
11670 install_element (BGP_NODE, &aggregate_address_mask_cmd);
11671 install_element (BGP_NODE, &aggregate_address_summary_only_cmd);
11672 install_element (BGP_NODE, &aggregate_address_mask_summary_only_cmd);
11673 install_element (BGP_NODE, &aggregate_address_as_set_cmd);
11674 install_element (BGP_NODE, &aggregate_address_mask_as_set_cmd);
11675 install_element (BGP_NODE, &aggregate_address_as_set_summary_cmd);
11676 install_element (BGP_NODE, &aggregate_address_mask_as_set_summary_cmd);
11677 install_element (BGP_NODE, &aggregate_address_summary_as_set_cmd);
11678 install_element (BGP_NODE, &aggregate_address_mask_summary_as_set_cmd);
11679 install_element (BGP_NODE, &no_aggregate_address_cmd);
11680 install_element (BGP_NODE, &no_aggregate_address_summary_only_cmd);
11681 install_element (BGP_NODE, &no_aggregate_address_as_set_cmd);
11682 install_element (BGP_NODE, &no_aggregate_address_as_set_summary_cmd);
11683 install_element (BGP_NODE, &no_aggregate_address_summary_as_set_cmd);
11684 install_element (BGP_NODE, &no_aggregate_address_mask_cmd);
11685 install_element (BGP_NODE, &no_aggregate_address_mask_summary_only_cmd);
11686 install_element (BGP_NODE, &no_aggregate_address_mask_as_set_cmd);
11687 install_element (BGP_NODE, &no_aggregate_address_mask_as_set_summary_cmd);
11688 install_element (BGP_NODE, &no_aggregate_address_mask_summary_as_set_cmd);
11689
11690 /* IPv4 unicast configuration. */
11691 install_element (BGP_IPV4_NODE, &bgp_network_cmd);
11692 install_element (BGP_IPV4_NODE, &bgp_network_mask_cmd);
11693 install_element (BGP_IPV4_NODE, &bgp_network_mask_natural_cmd);
11694 install_element (BGP_IPV4_NODE, &bgp_network_route_map_cmd);
11695 install_element (BGP_IPV4_NODE, &bgp_network_mask_route_map_cmd);
11696 install_element (BGP_IPV4_NODE, &bgp_network_mask_natural_route_map_cmd);
41367172
PJ
11697 install_element (BGP_IPV4_NODE, &bgp_network_ttl_cmd);
11698 install_element (BGP_IPV4_NODE, &bgp_network_mask_ttl_cmd);
11699 install_element (BGP_IPV4_NODE, &bgp_network_mask_natural_ttl_cmd);
11700 install_element (BGP_IPV4_NODE, &bgp_network_backdoor_ttl_cmd);
11701 install_element (BGP_IPV4_NODE, &bgp_network_mask_backdoor_ttl_cmd);
11702 install_element (BGP_IPV4_NODE, &bgp_network_mask_natural_backdoor_ttl_cmd); install_element (BGP_IPV4_NODE, &no_bgp_network_cmd);
718e3744 11703 install_element (BGP_IPV4_NODE, &no_bgp_network_mask_cmd);
11704 install_element (BGP_IPV4_NODE, &no_bgp_network_mask_natural_cmd);
11705 install_element (BGP_IPV4_NODE, &no_bgp_network_route_map_cmd);
11706 install_element (BGP_IPV4_NODE, &no_bgp_network_mask_route_map_cmd);
11707 install_element (BGP_IPV4_NODE, &no_bgp_network_mask_natural_route_map_cmd);
41367172
PJ
11708 install_element (BGP_IPV4_NODE, &no_bgp_network_ttl_cmd);
11709 install_element (BGP_IPV4_NODE, &no_bgp_network_mask_ttl_cmd);
11710 install_element (BGP_IPV4_NODE, &no_bgp_network_mask_natural_ttl_cmd);
11711 install_element (BGP_IPV4_NODE, &no_bgp_network_backdoor_ttl_cmd);
11712 install_element (BGP_IPV4_NODE, &no_bgp_network_mask_backdoor_ttl_cmd);
11713 install_element (BGP_IPV4_NODE, &no_bgp_network_mask_natural_backdoor_ttl_cmd); install_element (BGP_IPV4_NODE, &no_bgp_network_cmd);
718e3744 11714 install_element (BGP_IPV4_NODE, &aggregate_address_cmd);
11715 install_element (BGP_IPV4_NODE, &aggregate_address_mask_cmd);
11716 install_element (BGP_IPV4_NODE, &aggregate_address_summary_only_cmd);
11717 install_element (BGP_IPV4_NODE, &aggregate_address_mask_summary_only_cmd);
11718 install_element (BGP_IPV4_NODE, &aggregate_address_as_set_cmd);
11719 install_element (BGP_IPV4_NODE, &aggregate_address_mask_as_set_cmd);
11720 install_element (BGP_IPV4_NODE, &aggregate_address_as_set_summary_cmd);
11721 install_element (BGP_IPV4_NODE, &aggregate_address_mask_as_set_summary_cmd);
11722 install_element (BGP_IPV4_NODE, &aggregate_address_summary_as_set_cmd);
11723 install_element (BGP_IPV4_NODE, &aggregate_address_mask_summary_as_set_cmd);
11724 install_element (BGP_IPV4_NODE, &no_aggregate_address_cmd);
11725 install_element (BGP_IPV4_NODE, &no_aggregate_address_summary_only_cmd);
11726 install_element (BGP_IPV4_NODE, &no_aggregate_address_as_set_cmd);
11727 install_element (BGP_IPV4_NODE, &no_aggregate_address_as_set_summary_cmd);
11728 install_element (BGP_IPV4_NODE, &no_aggregate_address_summary_as_set_cmd);
11729 install_element (BGP_IPV4_NODE, &no_aggregate_address_mask_cmd);
11730 install_element (BGP_IPV4_NODE, &no_aggregate_address_mask_summary_only_cmd);
11731 install_element (BGP_IPV4_NODE, &no_aggregate_address_mask_as_set_cmd);
11732 install_element (BGP_IPV4_NODE, &no_aggregate_address_mask_as_set_summary_cmd);
11733 install_element (BGP_IPV4_NODE, &no_aggregate_address_mask_summary_as_set_cmd);
11734
11735 /* IPv4 multicast configuration. */
11736 install_element (BGP_IPV4M_NODE, &bgp_network_cmd);
11737 install_element (BGP_IPV4M_NODE, &bgp_network_mask_cmd);
11738 install_element (BGP_IPV4M_NODE, &bgp_network_mask_natural_cmd);
11739 install_element (BGP_IPV4M_NODE, &bgp_network_route_map_cmd);
11740 install_element (BGP_IPV4M_NODE, &bgp_network_mask_route_map_cmd);
11741 install_element (BGP_IPV4M_NODE, &bgp_network_mask_natural_route_map_cmd);
41367172
PJ
11742 install_element (BGP_IPV4M_NODE, &bgp_network_ttl_cmd);
11743 install_element (BGP_IPV4M_NODE, &bgp_network_mask_ttl_cmd);
11744 install_element (BGP_IPV4M_NODE, &bgp_network_mask_natural_ttl_cmd);
11745 install_element (BGP_IPV4M_NODE, &bgp_network_backdoor_ttl_cmd);
11746 install_element (BGP_IPV4M_NODE, &bgp_network_mask_backdoor_ttl_cmd);
11747 install_element (BGP_IPV4M_NODE, &bgp_network_mask_natural_backdoor_ttl_cmd); install_element (BGP_IPV4_NODE, &no_bgp_network_cmd);
718e3744 11748 install_element (BGP_IPV4M_NODE, &no_bgp_network_cmd);
11749 install_element (BGP_IPV4M_NODE, &no_bgp_network_mask_cmd);
11750 install_element (BGP_IPV4M_NODE, &no_bgp_network_mask_natural_cmd);
11751 install_element (BGP_IPV4M_NODE, &no_bgp_network_route_map_cmd);
11752 install_element (BGP_IPV4M_NODE, &no_bgp_network_mask_route_map_cmd);
11753 install_element (BGP_IPV4M_NODE, &no_bgp_network_mask_natural_route_map_cmd);
41367172
PJ
11754 install_element (BGP_IPV4M_NODE, &no_bgp_network_ttl_cmd);
11755 install_element (BGP_IPV4M_NODE, &no_bgp_network_mask_ttl_cmd);
11756 install_element (BGP_IPV4M_NODE, &no_bgp_network_mask_natural_ttl_cmd);
11757 install_element (BGP_IPV4M_NODE, &no_bgp_network_backdoor_ttl_cmd);
11758 install_element (BGP_IPV4M_NODE, &no_bgp_network_mask_backdoor_ttl_cmd);
11759 install_element (BGP_IPV4M_NODE, &no_bgp_network_mask_natural_backdoor_ttl_cmd); install_element (BGP_IPV4_NODE, &no_bgp_network_cmd);
718e3744 11760 install_element (BGP_IPV4M_NODE, &aggregate_address_cmd);
11761 install_element (BGP_IPV4M_NODE, &aggregate_address_mask_cmd);
11762 install_element (BGP_IPV4M_NODE, &aggregate_address_summary_only_cmd);
11763 install_element (BGP_IPV4M_NODE, &aggregate_address_mask_summary_only_cmd);
11764 install_element (BGP_IPV4M_NODE, &aggregate_address_as_set_cmd);
11765 install_element (BGP_IPV4M_NODE, &aggregate_address_mask_as_set_cmd);
11766 install_element (BGP_IPV4M_NODE, &aggregate_address_as_set_summary_cmd);
11767 install_element (BGP_IPV4M_NODE, &aggregate_address_mask_as_set_summary_cmd);
11768 install_element (BGP_IPV4M_NODE, &aggregate_address_summary_as_set_cmd);
11769 install_element (BGP_IPV4M_NODE, &aggregate_address_mask_summary_as_set_cmd);
11770 install_element (BGP_IPV4M_NODE, &no_aggregate_address_cmd);
11771 install_element (BGP_IPV4M_NODE, &no_aggregate_address_summary_only_cmd);
11772 install_element (BGP_IPV4M_NODE, &no_aggregate_address_as_set_cmd);
11773 install_element (BGP_IPV4M_NODE, &no_aggregate_address_as_set_summary_cmd);
11774 install_element (BGP_IPV4M_NODE, &no_aggregate_address_summary_as_set_cmd);
11775 install_element (BGP_IPV4M_NODE, &no_aggregate_address_mask_cmd);
11776 install_element (BGP_IPV4M_NODE, &no_aggregate_address_mask_summary_only_cmd);
11777 install_element (BGP_IPV4M_NODE, &no_aggregate_address_mask_as_set_cmd);
11778 install_element (BGP_IPV4M_NODE, &no_aggregate_address_mask_as_set_summary_cmd);
11779 install_element (BGP_IPV4M_NODE, &no_aggregate_address_mask_summary_as_set_cmd);
11780
11781 install_element (VIEW_NODE, &show_ip_bgp_cmd);
11782 install_element (VIEW_NODE, &show_ip_bgp_ipv4_cmd);
11783 install_element (VIEW_NODE, &show_ip_bgp_route_cmd);
11784 install_element (VIEW_NODE, &show_ip_bgp_ipv4_route_cmd);
11785 install_element (VIEW_NODE, &show_ip_bgp_vpnv4_all_route_cmd);
11786 install_element (VIEW_NODE, &show_ip_bgp_vpnv4_rd_route_cmd);
11787 install_element (VIEW_NODE, &show_ip_bgp_prefix_cmd);
11788 install_element (VIEW_NODE, &show_ip_bgp_ipv4_prefix_cmd);
11789 install_element (VIEW_NODE, &show_ip_bgp_vpnv4_all_prefix_cmd);
11790 install_element (VIEW_NODE, &show_ip_bgp_vpnv4_rd_prefix_cmd);
11791 install_element (VIEW_NODE, &show_ip_bgp_view_cmd);
11792 install_element (VIEW_NODE, &show_ip_bgp_view_route_cmd);
11793 install_element (VIEW_NODE, &show_ip_bgp_view_prefix_cmd);
11794 install_element (VIEW_NODE, &show_ip_bgp_regexp_cmd);
11795 install_element (VIEW_NODE, &show_ip_bgp_ipv4_regexp_cmd);
11796 install_element (VIEW_NODE, &show_ip_bgp_prefix_list_cmd);
11797 install_element (VIEW_NODE, &show_ip_bgp_ipv4_prefix_list_cmd);
11798 install_element (VIEW_NODE, &show_ip_bgp_filter_list_cmd);
11799 install_element (VIEW_NODE, &show_ip_bgp_ipv4_filter_list_cmd);
11800 install_element (VIEW_NODE, &show_ip_bgp_route_map_cmd);
11801 install_element (VIEW_NODE, &show_ip_bgp_ipv4_route_map_cmd);
11802 install_element (VIEW_NODE, &show_ip_bgp_cidr_only_cmd);
11803 install_element (VIEW_NODE, &show_ip_bgp_ipv4_cidr_only_cmd);
11804 install_element (VIEW_NODE, &show_ip_bgp_community_all_cmd);
11805 install_element (VIEW_NODE, &show_ip_bgp_ipv4_community_all_cmd);
11806 install_element (VIEW_NODE, &show_ip_bgp_community_cmd);
11807 install_element (VIEW_NODE, &show_ip_bgp_community2_cmd);
11808 install_element (VIEW_NODE, &show_ip_bgp_community3_cmd);
11809 install_element (VIEW_NODE, &show_ip_bgp_community4_cmd);
11810 install_element (VIEW_NODE, &show_ip_bgp_ipv4_community_cmd);
11811 install_element (VIEW_NODE, &show_ip_bgp_ipv4_community2_cmd);
11812 install_element (VIEW_NODE, &show_ip_bgp_ipv4_community3_cmd);
11813 install_element (VIEW_NODE, &show_ip_bgp_ipv4_community4_cmd);
11814 install_element (VIEW_NODE, &show_ip_bgp_community_exact_cmd);
11815 install_element (VIEW_NODE, &show_ip_bgp_community2_exact_cmd);
11816 install_element (VIEW_NODE, &show_ip_bgp_community3_exact_cmd);
11817 install_element (VIEW_NODE, &show_ip_bgp_community4_exact_cmd);
11818 install_element (VIEW_NODE, &show_ip_bgp_ipv4_community_exact_cmd);
11819 install_element (VIEW_NODE, &show_ip_bgp_ipv4_community2_exact_cmd);
11820 install_element (VIEW_NODE, &show_ip_bgp_ipv4_community3_exact_cmd);
11821 install_element (VIEW_NODE, &show_ip_bgp_ipv4_community4_exact_cmd);
11822 install_element (VIEW_NODE, &show_ip_bgp_community_list_cmd);
11823 install_element (VIEW_NODE, &show_ip_bgp_ipv4_community_list_cmd);
11824 install_element (VIEW_NODE, &show_ip_bgp_community_list_exact_cmd);
11825 install_element (VIEW_NODE, &show_ip_bgp_ipv4_community_list_exact_cmd);
11826 install_element (VIEW_NODE, &show_ip_bgp_prefix_longer_cmd);
11827 install_element (VIEW_NODE, &show_ip_bgp_ipv4_prefix_longer_cmd);
11828 install_element (VIEW_NODE, &show_ip_bgp_neighbor_advertised_route_cmd);
11829 install_element (VIEW_NODE, &show_ip_bgp_ipv4_neighbor_advertised_route_cmd);
11830 install_element (VIEW_NODE, &show_ip_bgp_neighbor_received_routes_cmd);
11831 install_element (VIEW_NODE, &show_ip_bgp_ipv4_neighbor_received_routes_cmd);
11832 install_element (VIEW_NODE, &show_ip_bgp_neighbor_routes_cmd);
11833 install_element (VIEW_NODE, &show_ip_bgp_ipv4_neighbor_routes_cmd);
11834 install_element (VIEW_NODE, &show_ip_bgp_neighbor_received_prefix_filter_cmd);
11835 install_element (VIEW_NODE, &show_ip_bgp_ipv4_neighbor_received_prefix_filter_cmd);
11836 install_element (VIEW_NODE, &show_ip_bgp_dampened_paths_cmd);
11837 install_element (VIEW_NODE, &show_ip_bgp_flap_statistics_cmd);
11838 install_element (VIEW_NODE, &show_ip_bgp_flap_address_cmd);
11839 install_element (VIEW_NODE, &show_ip_bgp_flap_prefix_cmd);
11840 install_element (VIEW_NODE, &show_ip_bgp_flap_cidr_only_cmd);
11841 install_element (VIEW_NODE, &show_ip_bgp_flap_regexp_cmd);
11842 install_element (VIEW_NODE, &show_ip_bgp_flap_filter_list_cmd);
11843 install_element (VIEW_NODE, &show_ip_bgp_flap_prefix_list_cmd);
11844 install_element (VIEW_NODE, &show_ip_bgp_flap_prefix_longer_cmd);
11845 install_element (VIEW_NODE, &show_ip_bgp_flap_route_map_cmd);
11846 install_element (VIEW_NODE, &show_ip_bgp_neighbor_flap_cmd);
11847 install_element (VIEW_NODE, &show_ip_bgp_neighbor_damp_cmd);
fee0f4c6 11848 install_element (VIEW_NODE, &show_ip_bgp_rsclient_cmd);
11849 install_element (VIEW_NODE, &show_ip_bgp_rsclient_route_cmd);
11850 install_element (VIEW_NODE, &show_ip_bgp_rsclient_prefix_cmd);
2a71e9ce
TP
11851 install_element (VIEW_NODE, &show_ip_bgp_view_neighbor_advertised_route_cmd);
11852 install_element (VIEW_NODE, &show_ip_bgp_view_neighbor_received_routes_cmd);
fee0f4c6 11853 install_element (VIEW_NODE, &show_ip_bgp_view_rsclient_cmd);
11854 install_element (VIEW_NODE, &show_ip_bgp_view_rsclient_route_cmd);
11855 install_element (VIEW_NODE, &show_ip_bgp_view_rsclient_prefix_cmd);
62687ff1
PJ
11856
11857 /* Restricted node: VIEW_NODE - (set of dangerous commands) */
11858 install_element (RESTRICTED_NODE, &show_ip_bgp_route_cmd);
11859 install_element (RESTRICTED_NODE, &show_ip_bgp_ipv4_route_cmd);
11860 install_element (RESTRICTED_NODE, &show_ip_bgp_vpnv4_rd_route_cmd);
11861 install_element (RESTRICTED_NODE, &show_ip_bgp_prefix_cmd);
11862 install_element (RESTRICTED_NODE, &show_ip_bgp_ipv4_prefix_cmd);
11863 install_element (RESTRICTED_NODE, &show_ip_bgp_vpnv4_all_prefix_cmd);
11864 install_element (RESTRICTED_NODE, &show_ip_bgp_vpnv4_rd_prefix_cmd);
11865 install_element (RESTRICTED_NODE, &show_ip_bgp_view_route_cmd);
11866 install_element (RESTRICTED_NODE, &show_ip_bgp_view_prefix_cmd);
11867 install_element (RESTRICTED_NODE, &show_ip_bgp_community_cmd);
11868 install_element (RESTRICTED_NODE, &show_ip_bgp_community2_cmd);
11869 install_element (RESTRICTED_NODE, &show_ip_bgp_community3_cmd);
11870 install_element (RESTRICTED_NODE, &show_ip_bgp_community4_cmd);
11871 install_element (RESTRICTED_NODE, &show_ip_bgp_ipv4_community_cmd);
11872 install_element (RESTRICTED_NODE, &show_ip_bgp_ipv4_community2_cmd);
11873 install_element (RESTRICTED_NODE, &show_ip_bgp_ipv4_community3_cmd);
11874 install_element (RESTRICTED_NODE, &show_ip_bgp_ipv4_community4_cmd);
11875 install_element (RESTRICTED_NODE, &show_ip_bgp_community_exact_cmd);
11876 install_element (RESTRICTED_NODE, &show_ip_bgp_community2_exact_cmd);
11877 install_element (RESTRICTED_NODE, &show_ip_bgp_community3_exact_cmd);
11878 install_element (RESTRICTED_NODE, &show_ip_bgp_community4_exact_cmd);
11879 install_element (RESTRICTED_NODE, &show_ip_bgp_ipv4_community_exact_cmd);
11880 install_element (RESTRICTED_NODE, &show_ip_bgp_ipv4_community2_exact_cmd);
11881 install_element (RESTRICTED_NODE, &show_ip_bgp_ipv4_community3_exact_cmd);
11882 install_element (RESTRICTED_NODE, &show_ip_bgp_ipv4_community4_exact_cmd);
11883 install_element (RESTRICTED_NODE, &show_ip_bgp_rsclient_route_cmd);
11884 install_element (RESTRICTED_NODE, &show_ip_bgp_rsclient_prefix_cmd);
11885 install_element (RESTRICTED_NODE, &show_ip_bgp_view_rsclient_route_cmd);
11886 install_element (RESTRICTED_NODE, &show_ip_bgp_view_rsclient_prefix_cmd);
718e3744 11887
11888 install_element (ENABLE_NODE, &show_ip_bgp_cmd);
11889 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_cmd);
11890 install_element (ENABLE_NODE, &show_ip_bgp_route_cmd);
11891 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_route_cmd);
11892 install_element (ENABLE_NODE, &show_ip_bgp_vpnv4_all_route_cmd);
11893 install_element (ENABLE_NODE, &show_ip_bgp_vpnv4_rd_route_cmd);
11894 install_element (ENABLE_NODE, &show_ip_bgp_prefix_cmd);
11895 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_prefix_cmd);
11896 install_element (ENABLE_NODE, &show_ip_bgp_vpnv4_all_prefix_cmd);
11897 install_element (ENABLE_NODE, &show_ip_bgp_vpnv4_rd_prefix_cmd);
11898 install_element (ENABLE_NODE, &show_ip_bgp_view_cmd);
11899 install_element (ENABLE_NODE, &show_ip_bgp_view_route_cmd);
11900 install_element (ENABLE_NODE, &show_ip_bgp_view_prefix_cmd);
11901 install_element (ENABLE_NODE, &show_ip_bgp_regexp_cmd);
11902 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_regexp_cmd);
11903 install_element (ENABLE_NODE, &show_ip_bgp_prefix_list_cmd);
11904 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_prefix_list_cmd);
11905 install_element (ENABLE_NODE, &show_ip_bgp_filter_list_cmd);
11906 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_filter_list_cmd);
11907 install_element (ENABLE_NODE, &show_ip_bgp_route_map_cmd);
11908 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_route_map_cmd);
11909 install_element (ENABLE_NODE, &show_ip_bgp_cidr_only_cmd);
11910 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_cidr_only_cmd);
11911 install_element (ENABLE_NODE, &show_ip_bgp_community_all_cmd);
11912 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_community_all_cmd);
11913 install_element (ENABLE_NODE, &show_ip_bgp_community_cmd);
11914 install_element (ENABLE_NODE, &show_ip_bgp_community2_cmd);
11915 install_element (ENABLE_NODE, &show_ip_bgp_community3_cmd);
11916 install_element (ENABLE_NODE, &show_ip_bgp_community4_cmd);
11917 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_community_cmd);
11918 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_community2_cmd);
11919 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_community3_cmd);
11920 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_community4_cmd);
11921 install_element (ENABLE_NODE, &show_ip_bgp_community_exact_cmd);
11922 install_element (ENABLE_NODE, &show_ip_bgp_community2_exact_cmd);
11923 install_element (ENABLE_NODE, &show_ip_bgp_community3_exact_cmd);
11924 install_element (ENABLE_NODE, &show_ip_bgp_community4_exact_cmd);
11925 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_community_exact_cmd);
11926 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_community2_exact_cmd);
11927 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_community3_exact_cmd);
11928 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_community4_exact_cmd);
11929 install_element (ENABLE_NODE, &show_ip_bgp_community_list_cmd);
11930 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_community_list_cmd);
11931 install_element (ENABLE_NODE, &show_ip_bgp_community_list_exact_cmd);
11932 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_community_list_exact_cmd);
11933 install_element (ENABLE_NODE, &show_ip_bgp_prefix_longer_cmd);
11934 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_prefix_longer_cmd);
11935 install_element (ENABLE_NODE, &show_ip_bgp_neighbor_advertised_route_cmd);
11936 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_neighbor_advertised_route_cmd);
11937 install_element (ENABLE_NODE, &show_ip_bgp_neighbor_received_routes_cmd);
11938 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_neighbor_received_routes_cmd);
11939 install_element (ENABLE_NODE, &show_ip_bgp_neighbor_routes_cmd);
11940 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_neighbor_routes_cmd);
11941 install_element (ENABLE_NODE, &show_ip_bgp_neighbor_received_prefix_filter_cmd);
11942 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_neighbor_received_prefix_filter_cmd);
11943 install_element (ENABLE_NODE, &show_ip_bgp_dampened_paths_cmd);
11944 install_element (ENABLE_NODE, &show_ip_bgp_flap_statistics_cmd);
11945 install_element (ENABLE_NODE, &show_ip_bgp_flap_address_cmd);
11946 install_element (ENABLE_NODE, &show_ip_bgp_flap_prefix_cmd);
11947 install_element (ENABLE_NODE, &show_ip_bgp_flap_cidr_only_cmd);
11948 install_element (ENABLE_NODE, &show_ip_bgp_flap_regexp_cmd);
11949 install_element (ENABLE_NODE, &show_ip_bgp_flap_filter_list_cmd);
11950 install_element (ENABLE_NODE, &show_ip_bgp_flap_prefix_list_cmd);
11951 install_element (ENABLE_NODE, &show_ip_bgp_flap_prefix_longer_cmd);
11952 install_element (ENABLE_NODE, &show_ip_bgp_flap_route_map_cmd);
11953 install_element (ENABLE_NODE, &show_ip_bgp_neighbor_flap_cmd);
11954 install_element (ENABLE_NODE, &show_ip_bgp_neighbor_damp_cmd);
fee0f4c6 11955 install_element (ENABLE_NODE, &show_ip_bgp_rsclient_cmd);
11956 install_element (ENABLE_NODE, &show_ip_bgp_rsclient_route_cmd);
11957 install_element (ENABLE_NODE, &show_ip_bgp_rsclient_prefix_cmd);
2a71e9ce
TP
11958 install_element (ENABLE_NODE, &show_ip_bgp_view_neighbor_advertised_route_cmd);
11959 install_element (ENABLE_NODE, &show_ip_bgp_view_neighbor_received_routes_cmd);
fee0f4c6 11960 install_element (ENABLE_NODE, &show_ip_bgp_view_rsclient_cmd);
11961 install_element (ENABLE_NODE, &show_ip_bgp_view_rsclient_route_cmd);
11962 install_element (ENABLE_NODE, &show_ip_bgp_view_rsclient_prefix_cmd);
718e3744 11963
11964 /* BGP dampening clear commands */
11965 install_element (ENABLE_NODE, &clear_ip_bgp_dampening_cmd);
11966 install_element (ENABLE_NODE, &clear_ip_bgp_dampening_prefix_cmd);
11967 install_element (ENABLE_NODE, &clear_ip_bgp_dampening_address_cmd);
11968 install_element (ENABLE_NODE, &clear_ip_bgp_dampening_address_mask_cmd);
11969
ff7924f6
PJ
11970 /* prefix count */
11971 install_element (ENABLE_NODE, &show_ip_bgp_neighbor_prefix_counts_cmd);
11972 install_element (ENABLE_NODE, &show_ip_bgp_ipv4_neighbor_prefix_counts_cmd);
11973 install_element (ENABLE_NODE, &show_ip_bgp_vpnv4_neighbor_prefix_counts_cmd);
718e3744 11974#ifdef HAVE_IPV6
ff7924f6
PJ
11975 install_element (ENABLE_NODE, &show_bgp_ipv6_neighbor_prefix_counts_cmd);
11976
718e3744 11977 /* New config IPv6 BGP commands. */
11978 install_element (BGP_IPV6_NODE, &ipv6_bgp_network_cmd);
11979 install_element (BGP_IPV6_NODE, &ipv6_bgp_network_route_map_cmd);
41367172 11980 install_element (BGP_IPV6_NODE, &ipv6_bgp_network_ttl_cmd);
718e3744 11981 install_element (BGP_IPV6_NODE, &no_ipv6_bgp_network_cmd);
11982 install_element (BGP_IPV6_NODE, &no_ipv6_bgp_network_route_map_cmd);
41367172 11983 install_element (BGP_IPV6_NODE, &no_ipv6_bgp_network_ttl_cmd);
718e3744 11984
11985 install_element (BGP_IPV6_NODE, &ipv6_aggregate_address_cmd);
11986 install_element (BGP_IPV6_NODE, &ipv6_aggregate_address_summary_only_cmd);
11987 install_element (BGP_IPV6_NODE, &no_ipv6_aggregate_address_cmd);
11988 install_element (BGP_IPV6_NODE, &no_ipv6_aggregate_address_summary_only_cmd);
11989
11990 /* Old config IPv6 BGP commands. */
11991 install_element (BGP_NODE, &old_ipv6_bgp_network_cmd);
11992 install_element (BGP_NODE, &old_no_ipv6_bgp_network_cmd);
11993
11994 install_element (BGP_NODE, &old_ipv6_aggregate_address_cmd);
11995 install_element (BGP_NODE, &old_ipv6_aggregate_address_summary_only_cmd);
11996 install_element (BGP_NODE, &old_no_ipv6_aggregate_address_cmd);
11997 install_element (BGP_NODE, &old_no_ipv6_aggregate_address_summary_only_cmd);
11998
11999 install_element (VIEW_NODE, &show_bgp_cmd);
12000 install_element (VIEW_NODE, &show_bgp_ipv6_cmd);
12001 install_element (VIEW_NODE, &show_bgp_route_cmd);
12002 install_element (VIEW_NODE, &show_bgp_ipv6_route_cmd);
12003 install_element (VIEW_NODE, &show_bgp_prefix_cmd);
12004 install_element (VIEW_NODE, &show_bgp_ipv6_prefix_cmd);
12005 install_element (VIEW_NODE, &show_bgp_regexp_cmd);
12006 install_element (VIEW_NODE, &show_bgp_ipv6_regexp_cmd);
12007 install_element (VIEW_NODE, &show_bgp_prefix_list_cmd);
12008 install_element (VIEW_NODE, &show_bgp_ipv6_prefix_list_cmd);
12009 install_element (VIEW_NODE, &show_bgp_filter_list_cmd);
12010 install_element (VIEW_NODE, &show_bgp_ipv6_filter_list_cmd);
12011 install_element (VIEW_NODE, &show_bgp_route_map_cmd);
12012 install_element (VIEW_NODE, &show_bgp_ipv6_route_map_cmd);
12013 install_element (VIEW_NODE, &show_bgp_community_all_cmd);
12014 install_element (VIEW_NODE, &show_bgp_ipv6_community_all_cmd);
12015 install_element (VIEW_NODE, &show_bgp_community_cmd);
12016 install_element (VIEW_NODE, &show_bgp_ipv6_community_cmd);
12017 install_element (VIEW_NODE, &show_bgp_community2_cmd);
12018 install_element (VIEW_NODE, &show_bgp_ipv6_community2_cmd);
12019 install_element (VIEW_NODE, &show_bgp_community3_cmd);
12020 install_element (VIEW_NODE, &show_bgp_ipv6_community3_cmd);
12021 install_element (VIEW_NODE, &show_bgp_community4_cmd);
12022 install_element (VIEW_NODE, &show_bgp_ipv6_community4_cmd);
12023 install_element (VIEW_NODE, &show_bgp_community_exact_cmd);
12024 install_element (VIEW_NODE, &show_bgp_ipv6_community_exact_cmd);
12025 install_element (VIEW_NODE, &show_bgp_community2_exact_cmd);
12026 install_element (VIEW_NODE, &show_bgp_ipv6_community2_exact_cmd);
12027 install_element (VIEW_NODE, &show_bgp_community3_exact_cmd);
12028 install_element (VIEW_NODE, &show_bgp_ipv6_community3_exact_cmd);
12029 install_element (VIEW_NODE, &show_bgp_community4_exact_cmd);
12030 install_element (VIEW_NODE, &show_bgp_ipv6_community4_exact_cmd);
12031 install_element (VIEW_NODE, &show_bgp_community_list_cmd);
12032 install_element (VIEW_NODE, &show_bgp_ipv6_community_list_cmd);
12033 install_element (VIEW_NODE, &show_bgp_community_list_exact_cmd);
12034 install_element (VIEW_NODE, &show_bgp_ipv6_community_list_exact_cmd);
12035 install_element (VIEW_NODE, &show_bgp_prefix_longer_cmd);
12036 install_element (VIEW_NODE, &show_bgp_ipv6_prefix_longer_cmd);
12037 install_element (VIEW_NODE, &show_bgp_neighbor_advertised_route_cmd);
12038 install_element (VIEW_NODE, &show_bgp_ipv6_neighbor_advertised_route_cmd);
12039 install_element (VIEW_NODE, &show_bgp_neighbor_received_routes_cmd);
12040 install_element (VIEW_NODE, &show_bgp_ipv6_neighbor_received_routes_cmd);
12041 install_element (VIEW_NODE, &show_bgp_neighbor_routes_cmd);
12042 install_element (VIEW_NODE, &show_bgp_ipv6_neighbor_routes_cmd);
12043 install_element (VIEW_NODE, &show_bgp_neighbor_received_prefix_filter_cmd);
12044 install_element (VIEW_NODE, &show_bgp_ipv6_neighbor_received_prefix_filter_cmd);
bb46e94f 12045 install_element (VIEW_NODE, &show_bgp_neighbor_flap_cmd);
12046 install_element (VIEW_NODE, &show_bgp_ipv6_neighbor_flap_cmd);
12047 install_element (VIEW_NODE, &show_bgp_neighbor_damp_cmd);
12048 install_element (VIEW_NODE, &show_bgp_ipv6_neighbor_damp_cmd);
fee0f4c6 12049 install_element (VIEW_NODE, &show_bgp_rsclient_cmd);
12050 install_element (VIEW_NODE, &show_bgp_rsclient_route_cmd);
12051 install_element (VIEW_NODE, &show_bgp_rsclient_prefix_cmd);
bb46e94f 12052 install_element (VIEW_NODE, &show_bgp_view_cmd);
12053 install_element (VIEW_NODE, &show_bgp_view_ipv6_cmd);
12054 install_element (VIEW_NODE, &show_bgp_view_route_cmd);
12055 install_element (VIEW_NODE, &show_bgp_view_ipv6_route_cmd);
12056 install_element (VIEW_NODE, &show_bgp_view_prefix_cmd);
12057 install_element (VIEW_NODE, &show_bgp_view_ipv6_prefix_cmd);
12058 install_element (VIEW_NODE, &show_bgp_view_neighbor_advertised_route_cmd);
12059 install_element (VIEW_NODE, &show_bgp_view_ipv6_neighbor_advertised_route_cmd);
12060 install_element (VIEW_NODE, &show_bgp_view_neighbor_received_routes_cmd);
12061 install_element (VIEW_NODE, &show_bgp_view_ipv6_neighbor_received_routes_cmd);
12062 install_element (VIEW_NODE, &show_bgp_view_neighbor_routes_cmd);
12063 install_element (VIEW_NODE, &show_bgp_view_ipv6_neighbor_routes_cmd);
12064 install_element (VIEW_NODE, &show_bgp_view_neighbor_received_prefix_filter_cmd);
12065 install_element (VIEW_NODE, &show_bgp_view_ipv6_neighbor_received_prefix_filter_cmd);
12066 install_element (VIEW_NODE, &show_bgp_view_neighbor_flap_cmd);
12067 install_element (VIEW_NODE, &show_bgp_view_ipv6_neighbor_flap_cmd);
12068 install_element (VIEW_NODE, &show_bgp_view_neighbor_damp_cmd);
12069 install_element (VIEW_NODE, &show_bgp_view_ipv6_neighbor_damp_cmd);
fee0f4c6 12070 install_element (VIEW_NODE, &show_bgp_view_rsclient_cmd);
12071 install_element (VIEW_NODE, &show_bgp_view_rsclient_route_cmd);
12072 install_element (VIEW_NODE, &show_bgp_view_rsclient_prefix_cmd);
62687ff1
PJ
12073
12074 /* Restricted:
12075 * VIEW_NODE - (set of dangerous commands) - (commands dependent on prev)
12076 */
12077 install_element (RESTRICTED_NODE, &show_bgp_route_cmd);
12078 install_element (RESTRICTED_NODE, &show_bgp_ipv6_route_cmd);
12079 install_element (RESTRICTED_NODE, &show_bgp_prefix_cmd);
12080 install_element (RESTRICTED_NODE, &show_bgp_ipv6_prefix_cmd);
12081 install_element (RESTRICTED_NODE, &show_bgp_community_cmd);
12082 install_element (RESTRICTED_NODE, &show_bgp_ipv6_community_cmd);
12083 install_element (RESTRICTED_NODE, &show_bgp_community2_cmd);
12084 install_element (RESTRICTED_NODE, &show_bgp_ipv6_community2_cmd);
12085 install_element (RESTRICTED_NODE, &show_bgp_community3_cmd);
12086 install_element (RESTRICTED_NODE, &show_bgp_ipv6_community3_cmd);
12087 install_element (RESTRICTED_NODE, &show_bgp_community4_cmd);
12088 install_element (RESTRICTED_NODE, &show_bgp_ipv6_community4_cmd);
12089 install_element (RESTRICTED_NODE, &show_bgp_community_exact_cmd);
12090 install_element (RESTRICTED_NODE, &show_bgp_ipv6_community_exact_cmd);
12091 install_element (RESTRICTED_NODE, &show_bgp_community2_exact_cmd);
12092 install_element (RESTRICTED_NODE, &show_bgp_ipv6_community2_exact_cmd);
12093 install_element (RESTRICTED_NODE, &show_bgp_community3_exact_cmd);
12094 install_element (RESTRICTED_NODE, &show_bgp_ipv6_community3_exact_cmd);
12095 install_element (RESTRICTED_NODE, &show_bgp_community4_exact_cmd);
12096 install_element (RESTRICTED_NODE, &show_bgp_ipv6_community4_exact_cmd);
12097 install_element (RESTRICTED_NODE, &show_bgp_rsclient_route_cmd);
12098 install_element (RESTRICTED_NODE, &show_bgp_rsclient_prefix_cmd);
12099 install_element (RESTRICTED_NODE, &show_bgp_view_route_cmd);
12100 install_element (RESTRICTED_NODE, &show_bgp_view_ipv6_route_cmd);
12101 install_element (RESTRICTED_NODE, &show_bgp_view_prefix_cmd);
12102 install_element (RESTRICTED_NODE, &show_bgp_view_ipv6_prefix_cmd);
12103 install_element (RESTRICTED_NODE, &show_bgp_view_neighbor_received_prefix_filter_cmd);
12104 install_element (RESTRICTED_NODE, &show_bgp_view_ipv6_neighbor_received_prefix_filter_cmd);
12105 install_element (RESTRICTED_NODE, &show_bgp_view_rsclient_route_cmd);
12106 install_element (RESTRICTED_NODE, &show_bgp_view_rsclient_prefix_cmd);
718e3744 12107
12108 install_element (ENABLE_NODE, &show_bgp_cmd);
12109 install_element (ENABLE_NODE, &show_bgp_ipv6_cmd);
12110 install_element (ENABLE_NODE, &show_bgp_route_cmd);
12111 install_element (ENABLE_NODE, &show_bgp_ipv6_route_cmd);
12112 install_element (ENABLE_NODE, &show_bgp_prefix_cmd);
12113 install_element (ENABLE_NODE, &show_bgp_ipv6_prefix_cmd);
12114 install_element (ENABLE_NODE, &show_bgp_regexp_cmd);
12115 install_element (ENABLE_NODE, &show_bgp_ipv6_regexp_cmd);
12116 install_element (ENABLE_NODE, &show_bgp_prefix_list_cmd);
12117 install_element (ENABLE_NODE, &show_bgp_ipv6_prefix_list_cmd);
12118 install_element (ENABLE_NODE, &show_bgp_filter_list_cmd);
12119 install_element (ENABLE_NODE, &show_bgp_ipv6_filter_list_cmd);
12120 install_element (ENABLE_NODE, &show_bgp_route_map_cmd);
12121 install_element (ENABLE_NODE, &show_bgp_ipv6_route_map_cmd);
12122 install_element (ENABLE_NODE, &show_bgp_community_all_cmd);
12123 install_element (ENABLE_NODE, &show_bgp_ipv6_community_all_cmd);
12124 install_element (ENABLE_NODE, &show_bgp_community_cmd);
12125 install_element (ENABLE_NODE, &show_bgp_ipv6_community_cmd);
12126 install_element (ENABLE_NODE, &show_bgp_community2_cmd);
12127 install_element (ENABLE_NODE, &show_bgp_ipv6_community2_cmd);
12128 install_element (ENABLE_NODE, &show_bgp_community3_cmd);
12129 install_element (ENABLE_NODE, &show_bgp_ipv6_community3_cmd);
12130 install_element (ENABLE_NODE, &show_bgp_community4_cmd);
12131 install_element (ENABLE_NODE, &show_bgp_ipv6_community4_cmd);
12132 install_element (ENABLE_NODE, &show_bgp_community_exact_cmd);
12133 install_element (ENABLE_NODE, &show_bgp_ipv6_community_exact_cmd);
12134 install_element (ENABLE_NODE, &show_bgp_community2_exact_cmd);
12135 install_element (ENABLE_NODE, &show_bgp_ipv6_community2_exact_cmd);
12136 install_element (ENABLE_NODE, &show_bgp_community3_exact_cmd);
12137 install_element (ENABLE_NODE, &show_bgp_ipv6_community3_exact_cmd);
12138 install_element (ENABLE_NODE, &show_bgp_community4_exact_cmd);
12139 install_element (ENABLE_NODE, &show_bgp_ipv6_community4_exact_cmd);
12140 install_element (ENABLE_NODE, &show_bgp_community_list_cmd);
12141 install_element (ENABLE_NODE, &show_bgp_ipv6_community_list_cmd);
12142 install_element (ENABLE_NODE, &show_bgp_community_list_exact_cmd);
12143 install_element (ENABLE_NODE, &show_bgp_ipv6_community_list_exact_cmd);
12144 install_element (ENABLE_NODE, &show_bgp_prefix_longer_cmd);
12145 install_element (ENABLE_NODE, &show_bgp_ipv6_prefix_longer_cmd);
12146 install_element (ENABLE_NODE, &show_bgp_neighbor_advertised_route_cmd);
12147 install_element (ENABLE_NODE, &show_bgp_ipv6_neighbor_advertised_route_cmd);
12148 install_element (ENABLE_NODE, &show_bgp_neighbor_received_routes_cmd);
12149 install_element (ENABLE_NODE, &show_bgp_ipv6_neighbor_received_routes_cmd);
12150 install_element (ENABLE_NODE, &show_bgp_neighbor_routes_cmd);
12151 install_element (ENABLE_NODE, &show_bgp_ipv6_neighbor_routes_cmd);
12152 install_element (ENABLE_NODE, &show_bgp_neighbor_received_prefix_filter_cmd);
12153 install_element (ENABLE_NODE, &show_bgp_ipv6_neighbor_received_prefix_filter_cmd);
bb46e94f 12154 install_element (ENABLE_NODE, &show_bgp_neighbor_flap_cmd);
12155 install_element (ENABLE_NODE, &show_bgp_ipv6_neighbor_flap_cmd);
12156 install_element (ENABLE_NODE, &show_bgp_neighbor_damp_cmd);
12157 install_element (ENABLE_NODE, &show_bgp_ipv6_neighbor_damp_cmd);
fee0f4c6 12158 install_element (ENABLE_NODE, &show_bgp_rsclient_cmd);
12159 install_element (ENABLE_NODE, &show_bgp_rsclient_route_cmd);
12160 install_element (ENABLE_NODE, &show_bgp_rsclient_prefix_cmd);
bb46e94f 12161 install_element (ENABLE_NODE, &show_bgp_view_cmd);
12162 install_element (ENABLE_NODE, &show_bgp_view_ipv6_cmd);
12163 install_element (ENABLE_NODE, &show_bgp_view_route_cmd);
12164 install_element (ENABLE_NODE, &show_bgp_view_ipv6_route_cmd);
12165 install_element (ENABLE_NODE, &show_bgp_view_prefix_cmd);
12166 install_element (ENABLE_NODE, &show_bgp_view_ipv6_prefix_cmd);
12167 install_element (ENABLE_NODE, &show_bgp_view_neighbor_advertised_route_cmd);
12168 install_element (ENABLE_NODE, &show_bgp_view_ipv6_neighbor_advertised_route_cmd);
12169 install_element (ENABLE_NODE, &show_bgp_view_neighbor_received_routes_cmd);
12170 install_element (ENABLE_NODE, &show_bgp_view_ipv6_neighbor_received_routes_cmd);
12171 install_element (ENABLE_NODE, &show_bgp_view_neighbor_routes_cmd);
12172 install_element (ENABLE_NODE, &show_bgp_view_ipv6_neighbor_routes_cmd);
12173 install_element (ENABLE_NODE, &show_bgp_view_neighbor_received_prefix_filter_cmd);
12174 install_element (ENABLE_NODE, &show_bgp_view_ipv6_neighbor_received_prefix_filter_cmd);
12175 install_element (ENABLE_NODE, &show_bgp_view_neighbor_flap_cmd);
12176 install_element (ENABLE_NODE, &show_bgp_view_ipv6_neighbor_flap_cmd);
12177 install_element (ENABLE_NODE, &show_bgp_view_neighbor_damp_cmd);
12178 install_element (ENABLE_NODE, &show_bgp_view_ipv6_neighbor_damp_cmd);
fee0f4c6 12179 install_element (ENABLE_NODE, &show_bgp_view_rsclient_cmd);
12180 install_element (ENABLE_NODE, &show_bgp_view_rsclient_route_cmd);
12181 install_element (ENABLE_NODE, &show_bgp_view_rsclient_prefix_cmd);
2815e61f
PJ
12182
12183 /* Statistics */
12184 install_element (ENABLE_NODE, &show_bgp_statistics_cmd);
12185 install_element (ENABLE_NODE, &show_bgp_statistics_vpnv4_cmd);
12186 install_element (ENABLE_NODE, &show_bgp_statistics_view_cmd);
12187 install_element (ENABLE_NODE, &show_bgp_statistics_view_vpnv4_cmd);
12188
718e3744 12189 /* old command */
12190 install_element (VIEW_NODE, &show_ipv6_bgp_cmd);
12191 install_element (VIEW_NODE, &show_ipv6_bgp_route_cmd);
12192 install_element (VIEW_NODE, &show_ipv6_bgp_prefix_cmd);
12193 install_element (VIEW_NODE, &show_ipv6_bgp_regexp_cmd);
12194 install_element (VIEW_NODE, &show_ipv6_bgp_prefix_list_cmd);
12195 install_element (VIEW_NODE, &show_ipv6_bgp_filter_list_cmd);
12196 install_element (VIEW_NODE, &show_ipv6_bgp_community_all_cmd);
12197 install_element (VIEW_NODE, &show_ipv6_bgp_community_cmd);
12198 install_element (VIEW_NODE, &show_ipv6_bgp_community2_cmd);
12199 install_element (VIEW_NODE, &show_ipv6_bgp_community3_cmd);
12200 install_element (VIEW_NODE, &show_ipv6_bgp_community4_cmd);
12201 install_element (VIEW_NODE, &show_ipv6_bgp_community_exact_cmd);
12202 install_element (VIEW_NODE, &show_ipv6_bgp_community2_exact_cmd);
12203 install_element (VIEW_NODE, &show_ipv6_bgp_community3_exact_cmd);
12204 install_element (VIEW_NODE, &show_ipv6_bgp_community4_exact_cmd);
12205 install_element (VIEW_NODE, &show_ipv6_bgp_community_list_cmd);
12206 install_element (VIEW_NODE, &show_ipv6_bgp_community_list_exact_cmd);
12207 install_element (VIEW_NODE, &show_ipv6_bgp_prefix_longer_cmd);
12208 install_element (VIEW_NODE, &show_ipv6_mbgp_cmd);
12209 install_element (VIEW_NODE, &show_ipv6_mbgp_route_cmd);
12210 install_element (VIEW_NODE, &show_ipv6_mbgp_prefix_cmd);
12211 install_element (VIEW_NODE, &show_ipv6_mbgp_regexp_cmd);
12212 install_element (VIEW_NODE, &show_ipv6_mbgp_prefix_list_cmd);
12213 install_element (VIEW_NODE, &show_ipv6_mbgp_filter_list_cmd);
12214 install_element (VIEW_NODE, &show_ipv6_mbgp_community_all_cmd);
12215 install_element (VIEW_NODE, &show_ipv6_mbgp_community_cmd);
12216 install_element (VIEW_NODE, &show_ipv6_mbgp_community2_cmd);
12217 install_element (VIEW_NODE, &show_ipv6_mbgp_community3_cmd);
12218 install_element (VIEW_NODE, &show_ipv6_mbgp_community4_cmd);
12219 install_element (VIEW_NODE, &show_ipv6_mbgp_community_exact_cmd);
12220 install_element (VIEW_NODE, &show_ipv6_mbgp_community2_exact_cmd);
12221 install_element (VIEW_NODE, &show_ipv6_mbgp_community3_exact_cmd);
12222 install_element (VIEW_NODE, &show_ipv6_mbgp_community4_exact_cmd);
12223 install_element (VIEW_NODE, &show_ipv6_mbgp_community_list_cmd);
12224 install_element (VIEW_NODE, &show_ipv6_mbgp_community_list_exact_cmd);
12225 install_element (VIEW_NODE, &show_ipv6_mbgp_prefix_longer_cmd);
bb46e94f 12226
718e3744 12227 /* old command */
12228 install_element (ENABLE_NODE, &show_ipv6_bgp_cmd);
12229 install_element (ENABLE_NODE, &show_ipv6_bgp_route_cmd);
12230 install_element (ENABLE_NODE, &show_ipv6_bgp_prefix_cmd);
12231 install_element (ENABLE_NODE, &show_ipv6_bgp_regexp_cmd);
12232 install_element (ENABLE_NODE, &show_ipv6_bgp_prefix_list_cmd);
12233 install_element (ENABLE_NODE, &show_ipv6_bgp_filter_list_cmd);
12234 install_element (ENABLE_NODE, &show_ipv6_bgp_community_all_cmd);
12235 install_element (ENABLE_NODE, &show_ipv6_bgp_community_cmd);
12236 install_element (ENABLE_NODE, &show_ipv6_bgp_community2_cmd);
12237 install_element (ENABLE_NODE, &show_ipv6_bgp_community3_cmd);
12238 install_element (ENABLE_NODE, &show_ipv6_bgp_community4_cmd);
12239 install_element (ENABLE_NODE, &show_ipv6_bgp_community_exact_cmd);
12240 install_element (ENABLE_NODE, &show_ipv6_bgp_community2_exact_cmd);
12241 install_element (ENABLE_NODE, &show_ipv6_bgp_community3_exact_cmd);
12242 install_element (ENABLE_NODE, &show_ipv6_bgp_community4_exact_cmd);
12243 install_element (ENABLE_NODE, &show_ipv6_bgp_community_list_cmd);
12244 install_element (ENABLE_NODE, &show_ipv6_bgp_community_list_exact_cmd);
12245 install_element (ENABLE_NODE, &show_ipv6_bgp_prefix_longer_cmd);
12246 install_element (ENABLE_NODE, &show_ipv6_mbgp_cmd);
12247 install_element (ENABLE_NODE, &show_ipv6_mbgp_route_cmd);
12248 install_element (ENABLE_NODE, &show_ipv6_mbgp_prefix_cmd);
12249 install_element (ENABLE_NODE, &show_ipv6_mbgp_regexp_cmd);
12250 install_element (ENABLE_NODE, &show_ipv6_mbgp_prefix_list_cmd);
12251 install_element (ENABLE_NODE, &show_ipv6_mbgp_filter_list_cmd);
12252 install_element (ENABLE_NODE, &show_ipv6_mbgp_community_all_cmd);
12253 install_element (ENABLE_NODE, &show_ipv6_mbgp_community_cmd);
12254 install_element (ENABLE_NODE, &show_ipv6_mbgp_community2_cmd);
12255 install_element (ENABLE_NODE, &show_ipv6_mbgp_community3_cmd);
12256 install_element (ENABLE_NODE, &show_ipv6_mbgp_community4_cmd);
12257 install_element (ENABLE_NODE, &show_ipv6_mbgp_community_exact_cmd);
12258 install_element (ENABLE_NODE, &show_ipv6_mbgp_community2_exact_cmd);
12259 install_element (ENABLE_NODE, &show_ipv6_mbgp_community3_exact_cmd);
12260 install_element (ENABLE_NODE, &show_ipv6_mbgp_community4_exact_cmd);
12261 install_element (ENABLE_NODE, &show_ipv6_mbgp_community_list_cmd);
12262 install_element (ENABLE_NODE, &show_ipv6_mbgp_community_list_exact_cmd);
12263 install_element (ENABLE_NODE, &show_ipv6_mbgp_prefix_longer_cmd);
12264
12265 /* old command */
12266 install_element (VIEW_NODE, &ipv6_bgp_neighbor_advertised_route_cmd);
12267 install_element (ENABLE_NODE, &ipv6_bgp_neighbor_advertised_route_cmd);
12268 install_element (VIEW_NODE, &ipv6_mbgp_neighbor_advertised_route_cmd);
12269 install_element (ENABLE_NODE, &ipv6_mbgp_neighbor_advertised_route_cmd);
12270
12271 /* old command */
12272 install_element (VIEW_NODE, &ipv6_bgp_neighbor_received_routes_cmd);
12273 install_element (ENABLE_NODE, &ipv6_bgp_neighbor_received_routes_cmd);
12274 install_element (VIEW_NODE, &ipv6_mbgp_neighbor_received_routes_cmd);
12275 install_element (ENABLE_NODE, &ipv6_mbgp_neighbor_received_routes_cmd);
12276
12277 /* old command */
12278 install_element (VIEW_NODE, &ipv6_bgp_neighbor_routes_cmd);
12279 install_element (ENABLE_NODE, &ipv6_bgp_neighbor_routes_cmd);
12280 install_element (VIEW_NODE, &ipv6_mbgp_neighbor_routes_cmd);
12281 install_element (ENABLE_NODE, &ipv6_mbgp_neighbor_routes_cmd);
12282#endif /* HAVE_IPV6 */
12283
12284 install_element (BGP_NODE, &bgp_distance_cmd);
12285 install_element (BGP_NODE, &no_bgp_distance_cmd);
12286 install_element (BGP_NODE, &no_bgp_distance2_cmd);
12287 install_element (BGP_NODE, &bgp_distance_source_cmd);
12288 install_element (BGP_NODE, &no_bgp_distance_source_cmd);
12289 install_element (BGP_NODE, &bgp_distance_source_access_list_cmd);
12290 install_element (BGP_NODE, &no_bgp_distance_source_access_list_cmd);
12291
12292 install_element (BGP_NODE, &bgp_damp_set_cmd);
12293 install_element (BGP_NODE, &bgp_damp_set2_cmd);
12294 install_element (BGP_NODE, &bgp_damp_set3_cmd);
12295 install_element (BGP_NODE, &bgp_damp_unset_cmd);
12296 install_element (BGP_NODE, &bgp_damp_unset2_cmd);
12297 install_element (BGP_IPV4_NODE, &bgp_damp_set_cmd);
12298 install_element (BGP_IPV4_NODE, &bgp_damp_set2_cmd);
12299 install_element (BGP_IPV4_NODE, &bgp_damp_set3_cmd);
12300 install_element (BGP_IPV4_NODE, &bgp_damp_unset_cmd);
12301 install_element (BGP_IPV4_NODE, &bgp_damp_unset2_cmd);
12302}
228da428
CC
12303
12304void
12305bgp_route_finish (void)
12306{
12307 bgp_table_unlock (bgp_distance_table);
12308 bgp_distance_table = NULL;
12309}