diff options
-rw-r--r-- | bgpd/ChangeLog | 6 | ||||
-rw-r--r-- | bgpd/bgp_aspath.c | 24 | ||||
-rw-r--r-- | bgpd/bgp_aspath.h | 3 | ||||
-rw-r--r-- | bgpd/bgp_route.c | 24 | ||||
-rw-r--r-- | bgpd/bgp_vty.c | 36 | ||||
-rw-r--r-- | bgpd/bgpd.c | 2 | ||||
-rw-r--r-- | bgpd/bgpd.h | 1 | ||||
-rw-r--r-- | doc/ChangeLog | 4 | ||||
-rw-r--r-- | doc/bgpd.texi | 6 |
9 files changed, 95 insertions, 11 deletions
diff --git a/bgpd/ChangeLog b/bgpd/ChangeLog index 4c18fc39..6dc1e7e0 100644 --- a/bgpd/ChangeLog +++ b/bgpd/ChangeLog @@ -1,3 +1,9 @@ +2005-04-08 Martin Ling <martin-quagga@earth.li> + + * bgp_aspath.[ch], bgp_route.c, bgp_vty.c, bgpd.[ch]: Allow to enable + the length of confederation path segments to be included during the + as-path length check in the best path decision. + 2005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu> * bgp_zebra.c: (bgp_interface_delete) After deleting, set ifp->ifindex diff --git a/bgpd/bgp_aspath.c b/bgpd/bgp_aspath.c index 5d497751..0c50f6a6 100644 --- a/bgpd/bgp_aspath.c +++ b/bgpd/bgp_aspath.c @@ -138,6 +138,7 @@ aspath_make_str_count (struct aspath *as) int str_pnt; char *str_buf; int count = 0; + int confed_count = 0; /* Empty aspath. */ if (as->length == 0) @@ -145,6 +146,7 @@ aspath_make_str_count (struct aspath *as) str_buf = XMALLOC (MTYPE_AS_STR, 1); str_buf[0] = '\0'; as->count = count; + as->confed_count = confed_count; return str_buf; } @@ -208,14 +210,21 @@ aspath_make_str_count (struct aspath *as) space = 0; - /* Increment count - ignoring CONFED SETS/SEQUENCES */ - if (assegment->type != AS_CONFED_SEQUENCE - && assegment->type != AS_CONFED_SET) + /* Increment counts */ + switch (assegment->type) { - if (assegment->type == AS_SEQUENCE) - count += assegment->length; - else if (assegment->type == AS_SET) - count++; + case AS_SEQUENCE: + count += assegment->length; + break; + case AS_SET: + count++; + break; + case AS_CONFED_SEQUENCE: + confed_count += assegment->length; + break; + case AS_CONFED_SET: + confed_count++; + break; } for (i = 0; i < assegment->length; i++) @@ -247,6 +256,7 @@ aspath_make_str_count (struct aspath *as) str_buf[str_pnt] = '\0'; as->count = count; + as->confed_count = confed_count; return str_buf; } diff --git a/bgpd/bgp_aspath.h b/bgpd/bgp_aspath.h index 3f7858be..bfe4f5e8 100644 --- a/bgpd/bgp_aspath.h +++ b/bgpd/bgp_aspath.h @@ -42,6 +42,9 @@ struct aspath /* AS count. */ int count; + /* Confederation set/segment AS count. */ + int confed_count; + /* Rawdata. */ caddr_t data; diff --git a/bgpd/bgp_route.c b/bgpd/bgp_route.c index 4f3847d6..8d992495 100644 --- a/bgpd/bgp_route.c +++ b/bgpd/bgp_route.c @@ -213,10 +213,26 @@ bgp_info_cmp (struct bgp *bgp, struct bgp_info *new, struct bgp_info *exist) /* 4. AS path length check. */ if (! bgp_flag_check (bgp, BGP_FLAG_ASPATH_IGNORE)) { - if (new->attr->aspath->count < exist->attr->aspath->count) - return 1; - if (new->attr->aspath->count > exist->attr->aspath->count) - return 0; + if (bgp_flag_check (bgp, BGP_FLAG_ASPATH_CONFED)) + { + if ((new->attr->aspath->count + + new->attr->aspath->confed_count) + < (exist->attr->aspath->count + + exist->attr->aspath->confed_count)) + return 1; + if ((new->attr->aspath->count + + new->attr->aspath->confed_count) + > (exist->attr->aspath->count + + exist->attr->aspath->confed_count)) + return 0; + } + else + { + if (new->attr->aspath->count < exist->attr->aspath->count) + return 1; + if (new->attr->aspath->count > exist->attr->aspath->count) + return 0; + } } /* 5. Origin check. */ diff --git a/bgpd/bgp_vty.c b/bgpd/bgp_vty.c index 52025b76..f7a41f5b 100644 --- a/bgpd/bgp_vty.c +++ b/bgpd/bgp_vty.c @@ -971,6 +971,38 @@ DEFUN (no_bgp_bestpath_aspath_ignore, return CMD_SUCCESS; } +/* "bgp bestpath as-path confed" configuration. */ +DEFUN (bgp_bestpath_aspath_confed, + bgp_bestpath_aspath_confed_cmd, + "bgp bestpath as-path confed", + "BGP specific commands\n" + "Change the default bestpath selection\n" + "AS-path attribute\n" + "Compare path lengths including confederation sets & sequences in selecting a route\n") +{ + struct bgp *bgp; + + bgp = vty->index; + bgp_flag_set (bgp, BGP_FLAG_ASPATH_CONFED); + return CMD_SUCCESS; +} + +DEFUN (no_bgp_bestpath_aspath_confed, + no_bgp_bestpath_aspath_confed_cmd, + "no bgp bestpath as-path confed", + NO_STR + "BGP specific commands\n" + "Change the default bestpath selection\n" + "AS-path attribute\n" + "Compare path lengths including confederation sets & sequences in selecting a route\n") +{ + struct bgp *bgp; + + bgp = vty->index; + bgp_flag_unset (bgp, BGP_FLAG_ASPATH_CONFED); + return CMD_SUCCESS; +} + /* "bgp log-neighbor-changes" configuration. */ DEFUN (bgp_log_neighbor_changes, bgp_log_neighbor_changes_cmd, @@ -8626,6 +8658,10 @@ bgp_vty_init () install_element (BGP_NODE, &bgp_bestpath_aspath_ignore_cmd); install_element (BGP_NODE, &no_bgp_bestpath_aspath_ignore_cmd); + /* "bgp bestpath as-path confed" commands */ + install_element (BGP_NODE, &bgp_bestpath_aspath_confed_cmd); + install_element (BGP_NODE, &no_bgp_bestpath_aspath_confed_cmd); + /* "bgp log-neighbor-changes" commands */ install_element (BGP_NODE, &bgp_log_neighbor_changes_cmd); install_element (BGP_NODE, &no_bgp_log_neighbor_changes_cmd); diff --git a/bgpd/bgpd.c b/bgpd/bgpd.c index d1e8d969..0d1689ab 100644 --- a/bgpd/bgpd.c +++ b/bgpd/bgpd.c @@ -4751,6 +4751,8 @@ bgp_config_write (struct vty *vty) /* BGP bestpath method. */ if (bgp_flag_check (bgp, BGP_FLAG_ASPATH_IGNORE)) vty_out (vty, " bgp bestpath as-path ignore%s", VTY_NEWLINE); + if (bgp_flag_check (bgp, BGP_FLAG_ASPATH_CONFED)) + vty_out (vty, " bgp bestpath as-path confed%s", VTY_NEWLINE); if (bgp_flag_check (bgp, BGP_FLAG_COMPARE_ROUTER_ID)) vty_out (vty, " bgp bestpath compare-routerid%s", VTY_NEWLINE); if (bgp_flag_check (bgp, BGP_FLAG_MED_CONFED) diff --git a/bgpd/bgpd.h b/bgpd/bgpd.h index a6c11ffa..a0cf7e8e 100644 --- a/bgpd/bgpd.h +++ b/bgpd/bgpd.h @@ -101,6 +101,7 @@ struct bgp #define BGP_FLAG_NO_FAST_EXT_FAILOVER (1 << 10) #define BGP_FLAG_LOG_NEIGHBOR_CHANGES (1 << 11) #define BGP_FLAG_GRACEFUL_RESTART (1 << 12) +#define BGP_FLAG_ASPATH_CONFED (1 << 13) /* BGP Per AF flags */ u_int16_t af_flags[AFI_MAX][SAFI_MAX]; diff --git a/doc/ChangeLog b/doc/ChangeLog index f3734144..f07f06de 100644 --- a/doc/ChangeLog +++ b/doc/ChangeLog @@ -1,3 +1,7 @@ +2005-04-08 Hasso Tepper <hasso at quagga.net> + + * bgpd.texi: Document new "bgp bestpath as-path confed" command. + 2005-04-05 Paul Jakma <paul@dishone.st> * Makefile.am: Get rid of built_sources. It causes them to be added diff --git a/doc/bgpd.texi b/doc/bgpd.texi index 0e0a2708..43d97028 100644 --- a/doc/bgpd.texi +++ b/doc/bgpd.texi @@ -116,6 +116,12 @@ This command set distance value to @item 6. MED check. @end table +@deffn {BGP} {bgp bestpath as-path confed} {} +This command specifies that the length of confederation path sets and +sequences should should be taken into account during the BGP best path +decision process. +@end deffn + @node BGP network @section BGP network |