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

bgpd: Free up leaked memory in case where routemap is not used #18529

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

donaldsharp
Copy link
Member

Direct leak of 48 byte(s) in 1 object(s) allocated from:
0 0x7ff0084b83b7 in __interceptor_calloc ../../../../src/libsanitizer/asan/asan_malloc_linux.cpp:77
1 0x7ff00803a36d in qcalloc lib/memory.c:106
2 0x55b99cded6ba in aspath_dup bgpd/bgp_aspath.c:703
3 0x55b99cc7ed00 in route_set_aspath_exclude bgpd/bgp_routemap.c:2604
4 0x7ff0080a8f4c in route_map_apply_ext lib/routemap.c:2708
5 0x55b99cc0f5b5 in bgp_input_modifier bgpd/bgp_route.c:1925
6 0x55b99cc391ae in bgp_update bgpd/bgp_route.c:5205
7 0x55b99cc3ebd5 in bgp_nlri_parse_ip bgpd/bgp_route.c:7271
8 0x55b99cbe9be7 in bgp_nlri_parse bgpd/bgp_packet.c:338
9 0x55b99cbebf87 in bgp_update_receive bgpd/bgp_packet.c:2448
10 0x55b99cbfa9d2 in bgp_process_packet bgpd/bgp_packet.c:4046
11 0x7ff0080f0112 in event_call lib/event.c:2019
12 0x7ff00801b2b3 in frr_run lib/libfrr.c:1247
13 0x55b99caec8d7 in main bgpd/bgp_main.c:557
14 0x7ff007b0c249 in __libc_start_call_main ../sysdeps/nptl/libc_start_call_main.h:58

Memory is being leaked in this call path. Upon debugging it was found that the ase is not a aspath or exclude_all or exclude_aspath_acl.

Direct leak of 48 byte(s) in 1 object(s) allocated from:
    0 0x7ff0084b83b7 in __interceptor_calloc ../../../../src/libsanitizer/asan/asan_malloc_linux.cpp:77
    1 0x7ff00803a36d in qcalloc lib/memory.c:106
    2 0x55b99cded6ba in aspath_dup bgpd/bgp_aspath.c:703
    3 0x55b99cc7ed00 in route_set_aspath_exclude bgpd/bgp_routemap.c:2604
    4 0x7ff0080a8f4c in route_map_apply_ext lib/routemap.c:2708
    5 0x55b99cc0f5b5 in bgp_input_modifier bgpd/bgp_route.c:1925
    6 0x55b99cc391ae in bgp_update bgpd/bgp_route.c:5205
    7 0x55b99cc3ebd5 in bgp_nlri_parse_ip bgpd/bgp_route.c:7271
    8 0x55b99cbe9be7 in bgp_nlri_parse bgpd/bgp_packet.c:338
    9 0x55b99cbebf87 in bgp_update_receive bgpd/bgp_packet.c:2448
    10 0x55b99cbfa9d2 in bgp_process_packet bgpd/bgp_packet.c:4046
    11 0x7ff0080f0112 in event_call lib/event.c:2019
    12 0x7ff00801b2b3 in frr_run lib/libfrr.c:1247
    13 0x55b99caec8d7 in main bgpd/bgp_main.c:557
    14 0x7ff007b0c249 in __libc_start_call_main ../sysdeps/nptl/libc_start_call_main.h:58

Memory is being leaked in this call path.  Upon debugging it was
found that the ase is not a aspath or exclude_all or exclude_aspath_acl.

Signed-off-by: Donald Sharp <[email protected]>
@donaldsharp
Copy link
Member Author

@ton31337 and @pguibert6WIND, you both might have an opinion here. How can we be calling into a routemap where the ase->XXX value is not set to something usable? This happens in the bgp_set_aspath_exclude test. I didn't attempt to fully understand the code. I'm just stopping a memory leak. There might be a better way to handle this.

@ton31337
Copy link
Member

ton31337 commented Mar 27, 2025

I see that exclude_aspath_acl_name (name exists, but the actual ACL - not) exists too?

@donaldsharp
Copy link
Member Author

I'd personally not rather have to figure out how to properly implement that and just get the memory leak fixed. I'd be willing to withdraw the PR if someone else fixes it appropriately

@donaldsharp
Copy link
Member Author

ci:rerun

else if (ase->exclude_aspath_acl)
path->attr->aspath =
aspath_filter_exclude_acl(new_path,
ase->exclude_aspath_acl);
else
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reading this again, should we care about else at all here?

@RodrigoNardi
Copy link

CI:rerun Rerunning the CI after fix on "[CI] Verify Source" incorrectly reporting bad status

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants