Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

zebra: Cl to frr upstream zebra json #17532

Open
wants to merge 106 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
106 commits
Select commit Hold shift + click to select a range
f159940
zebra:add df flag into evpn esi json output
Apr 28, 2023
2899964
zebra: add vni bridge vlan info in json output
chiragshah6 Sep 13, 2022
a389731
zebra: add json support for svd vxlan type
chiragshah6 Feb 17, 2022
b57ad60
zebra: show nexthop-group rib brief json
Dec 19, 2023
aa12b80
zebra: Define a local MAC cache for EVPN
vivek-cumulus Jan 11, 2022
c5488c9
zebra: Display local MAC cache
vivek-cumulus Jan 11, 2022
5f458b3
zebra: json support
ashred-lnx Feb 23, 2022
7b1ac8b
zebra: static analyzer reported issue fixes
sougata-github-nvidia Dec 4, 2024
5dde8e1
topotests: Allow runing under both docker and podman
famfo Nov 26, 2024
e7eb1a1
topotests: bmp, create shared library for bmp
pguibert6WIND Oct 25, 2024
293833d
topotests: fix bmp_collector handling of empty as-path
pguibert6WIND Oct 28, 2024
5238553
topotests: bgp_bmp, use unified configuration
pguibert6WIND Nov 18, 2024
45f7229
tests: add py extension to bmpserver
louis-6wind Nov 20, 2024
26a7352
tests: fix bmp test parallelization
louis-6wind Nov 20, 2024
b90814a
tests: save bmp pcap in logdir instead of /tmp
louis-6wind Nov 21, 2024
9712936
topotests: save bgp_bmp json temp files to bmp log folder instead of …
pguibert6WIND Dec 2, 2024
4cdbdc8
bgpd: bgp_clist.c does not need jhash.h
donaldsharp Dec 2, 2024
f0a5e78
tests: bgp_lu_topo[1|2] should not use log files in /tmp
donaldsharp Dec 2, 2024
3d4e007
tests: bgp_nexthop_ipv6 remove unused reference to /tmp
donaldsharp Dec 2, 2024
92756e2
tests: zebra_rib should not use /tmp for log files
donaldsharp Dec 2, 2024
fa317c3
tests: pim_cand_rp_bsr uses /tmp directory and it should not
donaldsharp Dec 2, 2024
a6fe1ff
tests: simple_snmp_test should not use /tmp for logging
donaldsharp Dec 2, 2024
b1ba753
tests: pim_basic should not use /tmp for outputing of files
donaldsharp Dec 2, 2024
f51c537
tests: pim_autorp should not use /tmp
donaldsharp Dec 2, 2024
e5e59a1
tests: ospf_prefix_suppression should not use /tmp
donaldsharp Dec 2, 2024
2479d74
tests: ospf_p2mp should not use /tmp
donaldsharp Dec 2, 2024
5547663
tests: ospf_netns_vrf should not use /tmp
donaldsharp Dec 2, 2024
1cacc25
tests: ospf_multi_vrf_bgp_route_leak should not use /tmp
donaldsharp Dec 2, 2024
65187ff
tests: ospf_multi_instance should not use /tmp
donaldsharp Dec 2, 2024
35056d0
tests: ospf_metric_propagation do not use /tmp
donaldsharp Dec 2, 2024
a7aacf6
tests: bgp_snmp_mplsl3vpn should not use /tmp directory
donaldsharp Dec 2, 2024
01d289f
tests: bgp_route_server_client should not use /tmp
donaldsharp Dec 2, 2024
b519572
bgpd: Use peer group's member for BGP notify instead of the peer-group
ton31337 Nov 27, 2024
c2079f2
bgpd: Initialize as_type for peer-group as AS_UNSPECIFIED
ton31337 Dec 1, 2024
e0d6005
tests: Check if remote-as is not flushed once peer-group applied
ton31337 Dec 1, 2024
719f6e2
zebra: separate zebra ZAPI server open and accept
Oct 30, 2024
9bce8f0
pimd: Fix access-list memory leak in pimd
Nov 26, 2024
4e253c6
lib: Fix session re-establishment
donaldsharp Dec 3, 2024
b2440cd
lib: Allow setsockopt functions to return size set
donaldsharp Dec 3, 2024
93ea727
lib,vtysh: Use backoff setsockopt option for freebsd
donaldsharp Dec 3, 2024
fe5e066
lib: Print the reason why the route-map and/or the index parsing is done
ton31337 Dec 4, 2024
1b5ce05
pimd: igmp proxy joins should not be written as part of config
Dec 3, 2024
1b64d76
pimd: Prevent crash of pim when auto-rp's socket is not initialized
donaldsharp Dec 4, 2024
85b502e
pimd: implement MSDP shutdown command
rzalamena May 10, 2022
33dc89a
topotests: test MSDP shutdown command
rzalamena Nov 25, 2024
fdab494
doc: document shutdown command
rzalamena Nov 25, 2024
bd14767
lib: Speed up reconnection attempts for zapi
donaldsharp Dec 4, 2024
1276e8f
bgpd: fix unconfigure asdot neighbor
pguibert6WIND Dec 4, 2024
430d7cb
pimd: free igmp proxy joins on interface deletion
Dec 3, 2024
5779690
tests: bfd_profiles_topo1 is taking a long time to reconnect
donaldsharp Dec 5, 2024
31572eb
bgpd: shared_network is a bool, convert it to such
donaldsharp Dec 5, 2024
3d70b9e
bgpd: When bgp notices a change to shared_network inform bfd of it
donaldsharp Dec 5, 2024
b8979fb
tests: Convert to using `neighbor X timers connect 1` for exabgp usin…
donaldsharp Dec 4, 2024
e6028d0
tests: Fix invalid escape seq seen in bgp_nexthop_ipv6
donaldsharp Dec 4, 2024
f61dde2
bgpd: fix peer up message for loc-rib not sent
pguibert6WIND Dec 2, 2024
35f77c5
topotests: bmp, test that loc-rib peer up message is sent
pguibert6WIND Dec 3, 2024
b43750e
bgpd: Check if as_type is not specified when peer is a peer-group member
ton31337 Dec 6, 2024
805aaec
doc: remove no-op "netns NAMESPACE" command from the docs
idryzhov Nov 30, 2024
4be15e5
zebra: add deprecation notice for no-op netns command
idryzhov Dec 7, 2024
69ea3eb
zebra: use macro for one check
anlancs Dec 5, 2024
0589950
pimd: Move ACL handling to pim_util.c
Nov 25, 2024
3db9117
pimd,yang: Extend multicast boundary functionality
Nov 25, 2024
7fc110a
tests: Add basic multicast boundary test
Nov 14, 2024
6288ffd
doc: Expand ACL and multicast boundary documentation
Nov 14, 2024
d11bded
pimd: Convert boundary_oil_plist to struct prefix_list
Nov 26, 2024
7d19912
tests: Check if vpn routes can be imported if allowas-in is set
ton31337 Dec 8, 2024
b868757
bgpd: Import allowed routes with self AS if desired
ton31337 Dec 8, 2024
336fb43
bgpd: Print the actual prefix when we try to import in vpn_leak_to_vr…
ton31337 Dec 8, 2024
c5087cb
bgpd: Show which route-map is used when the prefix is filtered by rou…
ton31337 Dec 4, 2024
c55bc29
yang,pimd: support shutdown and SA limit
rzalamena May 10, 2022
02939de
pimd: implement MSDP peer SA limiting
rzalamena May 10, 2022
613956a
topotests: test new MSDP SA limit feature
rzalamena Nov 26, 2024
f28c740
doc: document new SA limit command
rzalamena Nov 26, 2024
c8b7a5f
bgpd: Fix bgp core with a possible Intf delete
raja-rajasekar Dec 10, 2024
8df3572
bgpd, topotests: fix wrong peer type for loc-rib peer events
pguibert6WIND Oct 30, 2024
9dcf9d8
topotests: bgp_bmp, expose peer_distinguisher in loc-rib
pguibert6WIND Oct 30, 2024
34d8770
bgpd: modify bmp_get_peer_distinguisher to support AFI_UNSPEC
pguibert6WIND Oct 30, 2024
f7b0f6f
bgpd: bmp, add peer distinguisher support for peer up/down
pguibert6WIND Oct 30, 2024
0a20ef9
bgpd, topotests: bmp, fix wrong peer type for vrf route messages
pguibert6WIND Oct 31, 2024
6a3e1e3
bgpd, topotests: bmp, fix wrong peer distinguisher for vrf route events
pguibert6WIND Oct 31, 2024
ff0e1f2
bgpd, topotests: bmp, fix wrong peer type for peer up/down events
pguibert6WIND Oct 31, 2024
e5596dd
bgpd, topotests: bmp, fix wrong peer distinguisher value for peer vrf…
pguibert6WIND Oct 31, 2024
b1f199d
bgpd: bmp, add peer type and distinguisher support for stat messages
pguibert6WIND Sep 23, 2024
07fbbb8
zebra: Reset MAC's remote sequence number appropriately
vivek-cumulus Jun 10, 2020
29a0680
bgpd: Check L3VNI status before announcing default
vivek-cumulus Jun 9, 2021
880d019
zebra: Reduce memory usage of streams for encoding packets
donaldsharp Jun 10, 2021
1dac801
pimd: skip init of mlag roles based on the zebra capabilities message
AnuradhaKaruppiah Jun 18, 2021
c90c58f
pbrd: fix vrf_unchanged which may depend on other seqs
Jul 29, 2021
396bc3e
watchfrr: increase restart timer 20s -> 90s
qlyoung Aug 11, 2021
1b8b747
zebra: Fix another ships in the night issue with WFI
donaldsharp Oct 18, 2021
a2ee9db
bgpd: only import specific route-types into EVIs
Nov 5, 2021
bb5632b
bgpd: copy asn of src vrf to evpn type5 route
chiragshah6 Jan 26, 2022
3e2a0f3
bgpd: Show which prefix is suppressed if debug out is enabled
ton31337 Dec 11, 2024
8f2f7f6
zebra: Remove tests for allocation failure
donaldsharp Dec 11, 2024
f8ba744
pim6d: ignore more MSDP callbacks
rzalamena Dec 11, 2024
dcf33d0
pimd: move MSDP configuration and initialization
rzalamena Dec 11, 2024
c9d6ea7
pimd: move all MSDP code to its own place
rzalamena Dec 11, 2024
78c5bb9
pimd: support originator id configuration
rzalamena May 10, 2022
c7d3e19
topotests: topology to test MSDP originator ID
rzalamena Dec 10, 2024
f0f2940
doc: document new command MSDP originator ID
rzalamena Dec 10, 2024
f4af5fe
bgpd: When calling bgp_process, prevent infinite loop
donaldsharp Dec 12, 2024
31cbe16
doc: Update the next release dates
ton31337 Dec 12, 2024
02d336d
pim6d: fix crash on clear ipv6 mroute
rzalamena Dec 11, 2024
3049a63
pimd,pim6d: optimize multicast prefix generation
rzalamena Dec 13, 2024
b131abf
zebra: Give a bit more data about zclient connection on errors
donaldsharp Dec 13, 2024
b43c276
tools: Add rip support bundle commands
donaldsharp Dec 13, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
161 changes: 99 additions & 62 deletions bgpd/bgp_bmp.c
Original file line number Diff line number Diff line change
Expand Up @@ -275,37 +275,33 @@ static inline int bmp_get_peer_type(struct peer *peer)
return bmp_get_peer_type_vrf(peer->bgp->vrf_id);
}

static inline int bmp_get_peer_distinguisher(struct bmp *bmp, afi_t afi,
uint8_t peer_type,
static inline int bmp_get_peer_distinguisher(struct bgp *bgp, afi_t afi, uint8_t peer_type,
uint64_t *result_ref)
{

/* remove this check when the other peer types get correct peer dist.
*(RFC7854) impl.
* for now, always return no error and 0 peer distinguisher as before
*/
if (peer_type != BMP_PEER_TYPE_LOC_RIB_INSTANCE)
return (*result_ref = 0);
/* use RD if set in VRF config */
struct prefix_rd *prd;

/* sending vrf_id or rd could be turned into an option at some point */
struct bgp *bgp = bmp->targets->bgp;
if (peer_type == BMP_PEER_TYPE_LOCAL_INSTANCE || bgp->vrf_id == VRF_UNKNOWN)
return 1;

/* vrf default => ok, distinguisher 0 */
if (bgp->inst_type == VRF_DEFAULT)
return (*result_ref = 0);

/* use RD if set in VRF config for this AFI */
struct prefix_rd *prd = &bgp->vpn_policy[afi].tovpn_rd;

if (CHECK_FLAG(bgp->vpn_policy[afi].flags,
BGP_VPN_POLICY_TOVPN_RD_SET)) {
prd = &bgp->vpn_policy[AFI_IP].tovpn_rd;
if ((afi == AFI_IP || afi == AFI_UNSPEC) &&
CHECK_FLAG(bgp->vpn_policy[AFI_IP].flags, BGP_VPN_POLICY_TOVPN_RD_SET)) {
memcpy(result_ref, prd->val, sizeof(prd->val));
return 0;
}

/* VRF has no id => error => message should be skipped */
if (bgp->vrf_id == VRF_UNKNOWN)
return 1;
prd = &bgp->vpn_policy[AFI_IP6].tovpn_rd;
if ((afi == AFI_IP6 || afi == AFI_UNSPEC) &&
CHECK_FLAG(bgp->vpn_policy[AFI_IP6].flags, BGP_VPN_POLICY_TOVPN_RD_SET)) {
memcpy(result_ref, prd->val, sizeof(prd->val));
return 0;
}

/* use VRF id converted to ::vrf_id 64bits format */
*result_ref = ((uint64_t)htonl(bgp->vrf_id)) << 32;
Expand Down Expand Up @@ -467,13 +463,23 @@ static struct stream *bmp_peerstate(struct peer *peer, bool down)
struct stream *s;
size_t len;
struct timeval uptime, uptime_real;
uint8_t peer_type;
bool is_locrib = false;
uint64_t peer_distinguisher = 0;

uptime.tv_sec = peer->uptime;
uptime.tv_usec = 0;
monotime_to_realtime(&uptime, &uptime_real);

uint8_t peer_type = bmp_get_peer_type(peer);
bool is_locrib = peer_type == BMP_PEER_TYPE_LOC_RIB_INSTANCE;
peer_type = bmp_get_peer_type(peer);
if (peer_type == BMP_PEER_TYPE_LOC_RIB_INSTANCE)
is_locrib = true;

if (bmp_get_peer_distinguisher(peer->bgp, AFI_UNSPEC, peer_type, &peer_distinguisher)) {
zlog_warn("skipping bmp message for peer %s: can't get peer distinguisher",
peer->host);
return NULL;
}

#define BGP_BMP_MAX_PACKET_SIZE 1024
#define BMP_PEERUP_INFO_TYPE_STRING 0
Expand All @@ -484,9 +490,7 @@ static struct stream *bmp_peerstate(struct peer *peer, bool down)

bmp_common_hdr(s, BMP_VERSION_3,
BMP_TYPE_PEER_UP_NOTIFICATION);
bmp_per_peer_hdr(s, peer->bgp, peer, 0,
BMP_PEER_TYPE_GLOBAL_INSTANCE, 0,
&uptime_real);
bmp_per_peer_hdr(s, peer->bgp, peer, 0, peer_type, peer_distinguisher, &uptime_real);

/* Local Address (16 bytes) */
if (is_locrib)
Expand Down Expand Up @@ -548,9 +552,7 @@ static struct stream *bmp_peerstate(struct peer *peer, bool down)

bmp_common_hdr(s, BMP_VERSION_3,
BMP_TYPE_PEER_DOWN_NOTIFICATION);
bmp_per_peer_hdr(s, peer->bgp, peer, 0,
BMP_PEER_TYPE_GLOBAL_INSTANCE, 0,
&uptime_real);
bmp_per_peer_hdr(s, peer->bgp, peer, 0, peer_type, peer_distinguisher, &uptime_real);

type_pos = stream_get_endp(s);
stream_putc(s, 0); /* placeholder for down reason */
Expand Down Expand Up @@ -604,8 +606,10 @@ static int bmp_send_peerup(struct bmp *bmp)
/* Walk down all peers */
for (ALL_LIST_ELEMENTS_RO(bmp->targets->bgp->peer, node, peer)) {
s = bmp_peerstate(peer, false);
pullwr_write_stream(bmp->pullwr, s);
stream_free(s);
if (s) {
pullwr_write_stream(bmp->pullwr, s);
stream_free(s);
}
}

return 0;
Expand All @@ -622,10 +626,10 @@ static int bmp_send_peerup_vrf(struct bmp *bmp)
bmp_bgp_update_vrf_status(bmpbgp, vrf_state_unknown);

s = bmp_peerstate(bmpbgp->bgp->peer_self, bmpbgp->vrf_state == vrf_state_down);

pullwr_write_stream(bmp->pullwr, s);
stream_free(s);

if (s) {
pullwr_write_stream(bmp->pullwr, s);
stream_free(s);
}
return 0;
}

Expand All @@ -636,6 +640,9 @@ static void bmp_send_all(struct bmp_bgp *bmpbgp, struct stream *s)
struct bmp_targets *bt;
struct bmp *bmp;

if (!s)
return;

frr_each(bmp_targets, &bmpbgp->targets, bt)
frr_each(bmp_session, &bt->sessions, bmp)
pullwr_write_stream(bmp->pullwr, s);
Expand All @@ -644,6 +651,9 @@ static void bmp_send_all(struct bmp_bgp *bmpbgp, struct stream *s)

static void bmp_send_all_safe(struct bmp_bgp *bmpbgp, struct stream *s)
{
if (!s)
return;

if (!bmpbgp) {
stream_free(s);
return;
Expand Down Expand Up @@ -771,14 +781,24 @@ static void bmp_wrmirror_lost(struct bmp *bmp, struct pullwr *pullwr)
{
struct stream *s;
struct timeval tv;
uint8_t peer_type_flag;
uint64_t peer_distinguisher = 0;

gettimeofday(&tv, NULL);

peer_type_flag = bmp_get_peer_type_vrf(bmp->targets->bgp->vrf_id);

if (bmp_get_peer_distinguisher(bmp->targets->bgp, AFI_UNSPEC, peer_type_flag,
&peer_distinguisher)) {
zlog_warn("skipping bmp message for reason: can't get peer distinguisher");
return;
}

s = stream_new(BGP_MAX_PACKET_SIZE);

bmp_common_hdr(s, BMP_VERSION_3, BMP_TYPE_ROUTE_MIRRORING);
bmp_per_peer_hdr(s, bmp->targets->bgp, bmp->targets->bgp->peer_self, 0,
BMP_PEER_TYPE_GLOBAL_INSTANCE, 0, &tv);
bmp_per_peer_hdr(s, bmp->targets->bgp, bmp->targets->bgp->peer_self, 0, peer_type_flag,
peer_distinguisher, &tv);

stream_putw(s, BMP_MIRROR_TLV_TYPE_INFO);
stream_putw(s, 2);
Expand All @@ -795,6 +815,8 @@ static bool bmp_wrmirror(struct bmp *bmp, struct pullwr *pullwr)
struct bmp_mirrorq *bmq;
struct peer *peer;
bool written = false;
uint8_t peer_type_flag;
uint64_t peer_distinguisher = 0;

if (bmp->mirror_lost) {
bmp_wrmirror_lost(bmp, pullwr);
Expand All @@ -812,12 +834,20 @@ static bool bmp_wrmirror(struct bmp *bmp, struct pullwr *pullwr)
goto out;
}

peer_type_flag = bmp_get_peer_type_vrf(bmp->targets->bgp->vrf_id);

if (bmp_get_peer_distinguisher(peer->bgp, AFI_UNSPEC, peer_type_flag, &peer_distinguisher)) {
zlog_warn("skipping bmp message for peer %s: can't get peer distinguisher",
peer->host);
goto out;
}

struct stream *s;
s = stream_new(BGP_MAX_PACKET_SIZE);

bmp_common_hdr(s, BMP_VERSION_3, BMP_TYPE_ROUTE_MIRRORING);
bmp_per_peer_hdr(s, bmp->targets->bgp, peer, 0,
BMP_PEER_TYPE_GLOBAL_INSTANCE, 0, &bmq->tv);
bmp_per_peer_hdr(s, bmp->targets->bgp, peer, 0, peer_type_flag, peer_distinguisher,
&bmq->tv);

/* BMP Mirror TLV. */
stream_putw(s, BMP_MIRROR_TLV_TYPE_BGP_MESSAGE);
Expand Down Expand Up @@ -967,8 +997,7 @@ static void bmp_eor(struct bmp *bmp, afi_t afi, safi_t safi, uint8_t flags,

uint64_t peer_distinguisher = 0;
/* skip this message if peer distinguisher is not available */
if (bmp_get_peer_distinguisher(bmp, afi, peer_type_flag,
&peer_distinguisher)) {
if (bmp_get_peer_distinguisher(peer->bgp, afi, peer_type_flag, &peer_distinguisher)) {
zlog_warn(
"skipping bmp message for reason: can't get peer distinguisher");
continue;
Expand Down Expand Up @@ -1096,8 +1125,7 @@ static void bmp_monitor(struct bmp *bmp, struct peer *peer, uint8_t flags,

uint64_t peer_distinguisher = 0;
/* skip this message if peer distinguisher is not available */
if (bmp_get_peer_distinguisher(bmp, afi, peer_type_flag,
&peer_distinguisher)) {
if (bmp_get_peer_distinguisher(peer->bgp, afi, peer_type_flag, &peer_distinguisher)) {
zlog_warn(
"skipping bmp message for reason: can't get peer distinguisher");
return;
Expand Down Expand Up @@ -1131,6 +1159,7 @@ static bool bmp_wrsync(struct bmp *bmp, struct pullwr *pullwr)
uint8_t bpi_num_labels, adjin_num_labels;
afi_t afi;
safi_t safi;
uint8_t peer_type_flag;

if (bmp->syncafi == AFI_MAX) {
FOREACH_AFI_SAFI (afi, safi) {
Expand Down Expand Up @@ -1173,6 +1202,8 @@ static bool bmp_wrsync(struct bmp *bmp, struct pullwr *pullwr)
struct bgp_path_info *bpi = NULL, *bpiter;
struct bgp_adj_in *adjin = NULL, *adjiter;

peer_type_flag = bmp_get_peer_type_vrf(bmp->targets->bgp->vrf_id);

if ((afi == AFI_L2VPN && safi == SAFI_EVPN) ||
(safi == SAFI_MPLS_VPN)) {
/* initialize syncrdpos to the first
Expand Down Expand Up @@ -1227,10 +1258,8 @@ static bool bmp_wrsync(struct bmp *bmp, struct pullwr *pullwr)
bmp->remote, afi2str(afi),
safi2str(safi));

bmp_eor(bmp, afi, safi, BMP_PEER_FLAG_L,
BMP_PEER_TYPE_GLOBAL_INSTANCE);
bmp_eor(bmp, afi, safi, 0,
BMP_PEER_TYPE_GLOBAL_INSTANCE);
bmp_eor(bmp, afi, safi, BMP_PEER_FLAG_L, peer_type_flag);
bmp_eor(bmp, afi, safi, 0, peer_type_flag);
bmp_eor(bmp, afi, safi, 0,
BMP_PEER_TYPE_LOC_RIB_INSTANCE);

Expand Down Expand Up @@ -1314,19 +1343,20 @@ static bool bmp_wrsync(struct bmp *bmp, struct pullwr *pullwr)
bpi_num_labels);
}

if (bpi)
peer_type_flag = bmp_get_peer_type(bpi->peer);

if (bpi && CHECK_FLAG(bpi->flags, BGP_PATH_VALID) &&
CHECK_FLAG(bmp->targets->afimon[afi][safi], BMP_MON_POSTPOLICY))
bmp_monitor(bmp, bpi->peer, BMP_PEER_FLAG_L,
BMP_PEER_TYPE_GLOBAL_INSTANCE, bn_p, prd, bpi->attr,
bmp_monitor(bmp, bpi->peer, BMP_PEER_FLAG_L, peer_type_flag, bn_p, prd, bpi->attr,
afi, safi, bpi->uptime,
bpi_num_labels ? bpi->extra->labels->label : NULL,
bpi_num_labels);
bpi_num_labels ? bpi->extra->labels->label : NULL, bpi_num_labels);

if (adjin) {
adjin_num_labels = adjin->labels ? adjin->labels->num_labels : 0;
bmp_monitor(bmp, adjin->peer, 0, BMP_PEER_TYPE_GLOBAL_INSTANCE, bn_p, prd,
adjin->attr, afi, safi, adjin->uptime,
adjin_num_labels ? &adjin->labels->label[0] : NULL, adjin_num_labels);
bmp_monitor(bmp, adjin->peer, 0, peer_type_flag, bn_p, prd, adjin->attr, afi, safi,
adjin->uptime, adjin_num_labels ? &adjin->labels->label[0] : NULL,
adjin_num_labels);
}

if (bn)
Expand Down Expand Up @@ -1465,6 +1495,7 @@ static bool bmp_wrqueue(struct bmp *bmp, struct pullwr *pullwr)
struct bgp_dest *bn = NULL;
bool written = false;
uint8_t bpi_num_labels, adjin_num_labels;
uint8_t peer_type_flag;

bqe = bmp_pull(bmp);
if (!bqe)
Expand Down Expand Up @@ -1505,6 +1536,8 @@ static bool bmp_wrqueue(struct bmp *bmp, struct pullwr *pullwr)
bn = bgp_safi_node_lookup(bmp->targets->bgp->rib[afi][safi], safi,
&bqe->p, prd);

peer_type_flag = bmp_get_peer_type(peer);

if (CHECK_FLAG(bmp->targets->afimon[afi][safi], BMP_MON_POSTPOLICY)) {
struct bgp_path_info *bpi;

Expand All @@ -1518,12 +1551,9 @@ static bool bmp_wrqueue(struct bmp *bmp, struct pullwr *pullwr)

bpi_num_labels = BGP_PATH_INFO_NUM_LABELS(bpi);

bmp_monitor(bmp, peer, BMP_PEER_FLAG_L,
BMP_PEER_TYPE_GLOBAL_INSTANCE, &bqe->p, prd,
bpi ? bpi->attr : NULL, afi, safi,
bpi ? bpi->uptime : monotime(NULL),
bpi_num_labels ? bpi->extra->labels->label : NULL,
bpi_num_labels);
bmp_monitor(bmp, peer, BMP_PEER_FLAG_L, peer_type_flag, &bqe->p, prd,
bpi ? bpi->attr : NULL, afi, safi, bpi ? bpi->uptime : monotime(NULL),
bpi_num_labels ? bpi->extra->labels->label : NULL, bpi_num_labels);
written = true;
}

Expand All @@ -1536,9 +1566,8 @@ static bool bmp_wrqueue(struct bmp *bmp, struct pullwr *pullwr)
break;
}
adjin_num_labels = adjin && adjin->labels ? adjin->labels->num_labels : 0;
bmp_monitor(bmp, peer, 0, BMP_PEER_TYPE_GLOBAL_INSTANCE, &bqe->p, prd,
adjin ? adjin->attr : NULL, afi, safi,
adjin ? adjin->uptime : monotime(NULL),
bmp_monitor(bmp, peer, 0, peer_type_flag, &bqe->p, prd, adjin ? adjin->attr : NULL,
afi, safi, adjin ? adjin->uptime : monotime(NULL),
adjin_num_labels ? &adjin->labels->label[0] : NULL, adjin_num_labels);
written = true;
}
Expand Down Expand Up @@ -1704,6 +1733,8 @@ static void bmp_stats(struct event *thread)
struct peer *peer;
struct listnode *node;
struct timeval tv;
uint8_t peer_type_flag;
uint64_t peer_distinguisher = 0;

if (bt->stat_msec)
event_add_timer_msec(bm->master, bmp_stats, bt, bt->stat_msec,
Expand All @@ -1720,8 +1751,14 @@ static void bmp_stats(struct event *thread)

s = stream_new(BGP_MAX_PACKET_SIZE);
bmp_common_hdr(s, BMP_VERSION_3, BMP_TYPE_STATISTICS_REPORT);
bmp_per_peer_hdr(s, bt->bgp, peer, 0,
BMP_PEER_TYPE_GLOBAL_INSTANCE, 0, &tv);
peer_type_flag = bmp_get_peer_type(peer);
if (bmp_get_peer_distinguisher(peer->bgp, AFI_UNSPEC, peer_type_flag,
&peer_distinguisher)) {
zlog_warn("skipping bmp message for peer %s: can't get peer distinguisher",
peer->host);
continue;
}
bmp_per_peer_hdr(s, bt->bgp, peer, 0, peer_type_flag, peer_distinguisher, &tv);

count_pos = stream_get_endp(s);
stream_putl(s, 0);
Expand Down
1 change: 0 additions & 1 deletion bgpd/bgp_clist.c
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@
#include "queue.h"
#include "filter.h"
#include "stream.h"
#include "jhash.h"
#include "frrstr.h"

#include "bgpd/bgpd.h"
Expand Down
Loading
Loading