diff options
| author | Martin Winter <mwinter@opensourcerouting.org> | 2021-08-26 23:48:27 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-08-26 23:48:27 +0200 |
| commit | 0640479f05d24903478121482584adac6e454f64 (patch) | |
| tree | d3b6058bbb48cf708ef11d7078fc0bf885cfc5de | |
| parent | 7ed45c9a1751f435357a24099ba788d58e99bdd6 (diff) | |
| parent | 013575f52865b8114dd047dbe7fdfdf325c7640c (diff) | |
Merge pull request #9501 from FRRouting/mergify/bp/stable/8.0/pr-9498
bgpd: fix update-source for ipv6 (backport #9498)
| -rw-r--r-- | bgpd/bgp_zebra.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/bgpd/bgp_zebra.c b/bgpd/bgp_zebra.c index 3f8dc82a44..e2171e03b7 100644 --- a/bgpd/bgp_zebra.c +++ b/bgpd/bgp_zebra.c @@ -837,6 +837,12 @@ bool bgp_zebra_nexthop_set(union sockunion *local, union sockunion *remote, if (direct) v6_ll_avail = if_get_ipv6_local( ifp, &nexthop->v6_local); + /* + * It's fine to not have a v6 LL when using + * update-source loopback/vrf + */ + if (!v6_ll_avail && if_is_loopback_or_vrf(ifp)) + v6_ll_avail = true; } else /* Link-local address. */ { |
