summaryrefslogtreecommitdiffstats
path: root/bgpd/bgp_route.c
diff options
context:
space:
mode:
authorPhilippe Guibert <philippe.guibert@6wind.com>2022-08-17 11:52:51 +0200
committerPhilippe Guibert <philippe.guibert@6wind.com>2022-09-05 22:26:33 +0200
commit4cd690ae4d16814b0d5098764790578dab39e4a2 (patch)
tree0754d947ea06e91e54de83c82c1d18601c5f4344 /bgpd/bgp_route.c
parenttopotests: add bgp vpnv4 over gre test (diff)
downloadfrr-4cd690ae4d16814b0d5098764790578dab39e4a2.tar.xz
frr-4cd690ae4d16814b0d5098764790578dab39e4a2.zip
bgpd: add 'mpls bgp forwarding' to ease mpls vpn ebgp peering
RFC4364 describes peerings between multiple AS domains, to ease the continuity of VPN services across multiple SPs. This commit implements a sub-set of IETF option b) described in chapter 10 b. The ASBR to ASBR approach is taken, with an EBGP peering between the two routers. The EBGP peering must be directly connected to the outgoing interface used. In those conditions, the next hop is directly connected, and there is no need to have a transport label to convey the VPN label. A new vty command is added on a per interface basis: This command if enabled, will permit to convey BGP VPN labels without any transport labels (i.e. with implicit-null label). restriction: this command is used only for EBGP directly connected peerings. Other use cases are not covered. Signed-off-by: Philippe Guibert <philippe.guibert@6wind.com>
Diffstat (limited to 'bgpd/bgp_route.c')
-rw-r--r--bgpd/bgp_route.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/bgpd/bgp_route.c b/bgpd/bgp_route.c
index f042d0bd9..b2bd38cbb 100644
--- a/bgpd/bgp_route.c
+++ b/bgpd/bgp_route.c
@@ -255,6 +255,9 @@ void bgp_path_info_extra_free(struct bgp_path_info_extra **extra)
if (e->bgp_orig)
bgp_unlock(e->bgp_orig);
+ if (e->peer_orig)
+ peer_unlock(e->peer_orig);
+
if (e->aggr_suppressors)
list_delete(&e->aggr_suppressors);