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

[swig]: Fix swig template memory leak on issue 17025 #1

Merged
merged 2 commits into from
Oct 8, 2024

Conversation

vincentchiang-ec
Copy link

Fix the issue sonic-net/sonic-buildimage#17025 about Redis set activity

Description

The issue reports a memory leak on the Redis set operations

Reason

  1. Didn't decrease the reference count after PySequence_GetItem
  2. Use the inappropriate Swig API and didn't release the string of SWIG_AsPtr_std_string

Fix:

  1. Refer PR: Fix swig template memory leak sonic-net/sonic-swss-common#859 from @praveenraja1
  2. Replace the API SWIG_AsPtr_std_string to SWIG_AsVal_std_string

Add unit test

To monitor there is no dramatic memory increment after a huge amount of Redis set operations.

mssonicbld and others added 2 commits October 8, 2024 03:34
…#836)

In the current implementation, the data from redis is passed directly
to the std::string(char*) constructor which truncates the data on the null
byte.
To support binary data that can contain null bytes, the redis reply
*str* is passed along with its *len* into the std::string(char*,size_t)
constructor that supports the input size.

Co-authored-by: Yakiv Huryk <[email protected]>
Co-authored-by: Ze Gan <[email protected]>
Fix the issue sonic-net/sonic-buildimage#17025 about Redis set activity

Description
The issue reports a memory leak on the Redis set operations

Reason
Didn't decrease the reference count after PySequence_GetItem
Use the inappropriate Swig API and didn't release the string of SWIG_AsPtr_std_string
Fix:
Refer PR: Fix swig template memory leak #859 from @praveenraja1
Replace the API SWIG_AsPtr_std_string to SWIG_AsVal_std_string
Add unit test
To monitor there is no dramatic memory increment after a huge amount of Redis set operations.

Signed-off-by: Ze Gan <[email protected]>
@vincentchiang-ec vincentchiang-ec merged commit 3ace199 into edge-core:202311.X Oct 8, 2024
1 check passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants