You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Hello, I was using PyO3 to bind this rust code to python and is now struggling with the memory ownership problem (more specifically, double free).
When I try to pass an lmr to python, I do std::mem::forget(lmr) to make rust forget about the memory, as the memory is already somehow transfered to python by some unsafe pointer operations.
However, according to my reasoning, I think the jemalloc strategy does not give up this memory even lmr.drop() is not called. Is this expected? Is there way to forget this memory in jemalloc strategy?
P.S. raw strategy works fine and no double free occurs.
The text was updated successfully, but these errors were encountered:
jemalloc strategy does not give up this memory even lmr.drop() is not called.
I don’t quite understand the meaning of this sentence.
Do you mean: Je free the memory even drop is not called?
I think lmr.drop() -> jemalloc::free() will not be called if you use forget(lmr), and the memory should keep the allocated state(is this what you mean give up?).
But, we have not conducted any analysis or testing on transferring MR between different frameworks. Welcome contributions of complete application cases and discussions on potential issues.
Hello, I was using PyO3 to bind this rust code to python and is now struggling with the memory ownership problem (more specifically, double free).
When I try to pass an lmr to python, I do
std::mem::forget(lmr)
to make rust forget about the memory, as the memory is already somehow transfered to python by some unsafe pointer operations.However, according to my reasoning, I think the jemalloc strategy does not give up this memory even
lmr.drop()
is not called. Is this expected? Is there way to forget this memory in jemalloc strategy?P.S. raw strategy works fine and no double free occurs.
The text was updated successfully, but these errors were encountered: