diff options
author | Vasilis Tsiligiannis <b_tsiligiannis@silverton.gr> | 2009-07-20 01:59:10 +0300 |
---|---|---|
committer | Paul Jakma <paul@quagga.net> | 2009-07-28 15:02:07 +0100 |
commit | 736d440845c8c0cfdb56b86254887bab5fc7f3f5 (patch) | |
tree | e1b7f27c18b03494509e9b9ef0a694b726630418 /bgpd | |
parent | ca87e1d37b3c30648e9bacb476a3c89729512f6d (diff) |
bgpd: Delete AS_CONFED_SEQUENCE when prepending an AS_SEQUENCE type segment
AS_CONFED_SEQUENCE segment should always be deleted when prepending
(e.g. with a route-map) an AS_SEQUENCE segment to an AS path. Otherwise,
AS_CONFED_SEQUENCE will not be deleted later when updating EBGP peers (since
it is not the leftmost segment) and will leak outside the confederation.
Diffstat (limited to 'bgpd')
-rw-r--r-- | bgpd/bgp_aspath.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/bgpd/bgp_aspath.c b/bgpd/bgp_aspath.c index e65541f9..440815b4 100644 --- a/bgpd/bgp_aspath.c +++ b/bgpd/bgp_aspath.c @@ -1208,6 +1208,10 @@ aspath_prepend (struct aspath *as1, struct aspath *as2) while (seg1 && seg1->next) seg1 = seg1->next; + /* Delete any AS_CONFED_SEQUENCE segment from as2. */ + if (seg1->type == AS_SEQUENCE && seg2->type == AS_CONFED_SEQUENCE) + as2 = aspath_delete_confed_seq (as2); + /* Compare last segment type of as1 and first segment type of as2. */ if (seg1->type != seg2->type) return aspath_merge (as1, as2); |