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
This is long overdue, but we need to publish some fixes to memory leaks in the repo. I will outline 2 tools and how to use them for finding these leaks. We need someone to take the task of fixing these. I will be a secondary contributor, helping whoever steps up if they need it along the way. This is a great way of diving into the C codebase with a goal, albeit challenging. Please comment on this if you want to take on the task.
Current Behavior
The two tools are cppcheck and valgrind. Cppcheck is the easier tool but is less informative. We can run this static analysis tool on c files. Run as such
cppcheck *.c
If we for example run this on onvm/onvm_nflib/onvm_config_common.c we get
Since cppcheck only does static analysis, it cannot check how much memory is lost through this, and certainly cannot see more than malloc. DPDK Valgrind is an adaptation on Valgrind that goes through the DPDK library and can also check Huge pages, which Valgrind cannot do. Valgrind is more complex in that we need to run commands a specific way. First, compile everything with USER_FLAGS=-g -O0. This will make sure Valgrind can see the line numbers of the files. We cannot run inside ./go.sh, so we need to write echo before the command on line 86 of go.sh. This will allow us to see the entire command of the manager instead of running it. It should be something like this:
The previous command runs onvm with -t 12, which tells ONVM to stop running after 12 seconds. Valgrind can only check leaks if the program exits on its own, so this is a good way of constraining it. Keep in mind that there are flaws to this, as Valgrind cannot handle multi-processor applications. Under the hood, it moves all threads to a single core to watch the execution path easier. This can make it up to 100 times slower (from what I've read) than normal.
Expected behavior/code
We expect to have no memory leaks, as our cleanup processes should be able to free all necessary data structures and threads allocated.
Steps to reproduce
I've outlined how to use Valgrind and cppcheck via cli.
Possible Solution
There are many memory leaks. Getting any of them fixed would be great. To start, we have a function called onvm_ft_free in onvm/onvm_nflib/onvm_flow_table.c. Valgrind shows us that onvm_ft_create is called, which creates a hash table and other variables. The cleanup method is never called anywhere in the code. This was probably an oversight but needs to be called somewhere so the data can be freed on the exit of the manager. As for calls to DPDK memory allocation, we should have a rte_free for every rte_malloc. This is certainly an oversimplification, but a start.
Additional context/Screenshots
Please reach reference me on this issue or reach out if there are issues getting this setup working. There is a reason we have leaks, and that's because they're difficult to find and fix! This needs to be done, and there are many ways to get started, even if we don't fix all the leaks in one go.
Use this command to find specific words in all C files recursively. grep -nrw . --include \*.c -e "malloc"
The text was updated successfully, but these errors were encountered:
Bug Report
This is long overdue, but we need to publish some fixes to memory leaks in the repo. I will outline 2 tools and how to use them for finding these leaks. We need someone to take the task of fixing these. I will be a secondary contributor, helping whoever steps up if they need it along the way. This is a great way of diving into the C codebase with a goal, albeit challenging. Please comment on this if you want to take on the task.
Current Behavior
The two tools are
cppcheck
andvalgrind
. Cppcheck is the easier tool but is less informative. We can run this static analysis tool on c files. Run as suchcppcheck *.c
If we for example run this on
onvm/onvm_nflib/onvm_config_common.c
we getTo help with testing, here is a script I made to run cppcheck on all the relevant C files in the repo.
Since cppcheck only does static analysis, it cannot check how much memory is lost through this, and certainly cannot see more than
malloc
. DPDK Valgrind is an adaptation on Valgrind that goes through the DPDK library and can also check Huge pages, which Valgrind cannot do. Valgrind is more complex in that we need to run commands a specific way. First, compile everything withUSER_FLAGS=-g -O0
. This will make sure Valgrind can see the line numbers of the files. We cannot run inside./go.sh
, so we need to writeecho
before the command on line 86 ofgo.sh
. This will allow us to see the entire command of the manager instead of running it. It should be something like this:Then we can run Valgrind-DPDK like this:
The previous command runs onvm with
-t 12
, which tells ONVM to stop running after 12 seconds. Valgrind can only check leaks if the program exits on its own, so this is a good way of constraining it. Keep in mind that there are flaws to this, as Valgrind cannot handle multi-processor applications. Under the hood, it moves all threads to a single core to watch the execution path easier. This can make it up to 100 times slower (from what I've read) than normal.Expected behavior/code
We expect to have no memory leaks, as our cleanup processes should be able to free all necessary data structures and threads allocated.
Steps to reproduce
I've outlined how to use Valgrind and cppcheck via cli.
Environment
cppcheck
version: 1.82valgrind
version: valgrind-3.13.0Possible Solution
There are many memory leaks. Getting any of them fixed would be great. To start, we have a function called
onvm_ft_free
inonvm/onvm_nflib/onvm_flow_table.c
. Valgrind shows us thatonvm_ft_create
is called, which creates a hash table and other variables. The cleanup method is never called anywhere in the code. This was probably an oversight but needs to be called somewhere so the data can be freed on the exit of the manager. As for calls to DPDK memory allocation, we should have arte_free
for everyrte_malloc
. This is certainly an oversimplification, but a start.Additional context/Screenshots
Please reach reference me on this issue or reach out if there are issues getting this setup working. There is a reason we have leaks, and that's because they're difficult to find and fix! This needs to be done, and there are many ways to get started, even if we don't fix all the leaks in one go.
Use this command to find specific words in all C files recursively.
grep -nrw . --include \*.c -e "malloc"
The text was updated successfully, but these errors were encountered: