From: Enke Chen Date: Thu, 9 Jan 2025 20:02:02 +0000 (-0800) Subject: bgpd: use igpmetric in bgp_aigp_metric_total() X-Git-Tag: docker/10.1.3~35^2 X-Git-Url: https://git.puffer.fish/?a=commitdiff_plain;h=d7f5113d901c51049df03d3afa2aaf1cac6a6188;p=mirror%2Ffrr.git bgpd: use igpmetric in bgp_aigp_metric_total() Use igpmetric from bgp_path_info in bgp_igp_metric_total() to be consistent with all other cases, e.g., as in bgp_path_info_cmp(). Signed-off-by: Enke Chen (cherry picked from commit b89e66a3bcd5644278f34ec5899b071066e102a1) --- diff --git a/bgpd/bgp_attr.h b/bgpd/bgp_attr.h index 10e6b0ffcc..74cff5a3a3 100644 --- a/bgpd/bgp_attr.h +++ b/bgpd/bgp_attr.h @@ -602,10 +602,11 @@ static inline uint64_t bgp_aigp_metric_total(struct bgp_path_info *bpi) { uint64_t aigp = bgp_attr_get_aigp_metric(bpi->attr); - if (bpi->nexthop) - return aigp + bpi->nexthop->metric; - else + /* Don't increment if it's locally sourced */ + if (bpi->peer == bpi->peer->bgp->peer_self) return aigp; + + return bpi->extra ? (aigp + bpi->extra->igpmetric) : aigp; } static inline struct cluster_list *bgp_attr_get_cluster(const struct attr *attr)