Valgrind未提供内存泄漏的源代码行。

huangapple go评论65阅读模式
英文:

Valgrind not giving source code line for memory leak

问题

I am using Valgrind, version 3.19.0 on an ARM platform.
我正在使用Valgrind,版本3.19.0,在ARM平台上。

I wrote a small program that has a memory leak; here's the source:
我写了一个有内存泄漏的小程序;以下是源代码:

  1. #include <stdlib.h>
  2. int main()
  3. {
  4. char* p = (char*)malloc(1024 * 1024);
  5. return 0;
  6. }

I compiled it with:
我使用以下命令编译它:

  1. arm-buildroot-linux-gnueabi-gcc -g -O0 -o test test.c

Then run with Valgrind on my ARM machine:
然后在我的ARM机器上使用Valgrind运行:

  1. valgrind --leak-check=full --show-leak-kinds=all --track-origins=yes --verbose ./test

Looks like Valgrind successfully detects the leak, but it gives no info about the source code. Here's the output:
看起来Valgrind成功检测到了内存泄漏,但没有提供有关源代码的信息。以下是输出:

  1. ==1221== Memcheck, a memory error detector
  2. ==1221== Copyright (C) 2002-2022, and GNU GPL'd, by Julian Seward et al.
  3. ==1221== Using Valgrind-3.19.0 and LibVEX; rerun with -h for copyright info
  4. ==1221== Command: ./test
  5. ==1221==
  6. ==1221==
  7. ==1221== HEAP SUMMARY:
  8. ==1221== in use at exit: 1,048,576 bytes in 1 block
  9. ==1221== total heap usage: 2 allocs, 1 frees, 1,068,800 bytes allocated
  10. ==1221==
  11. ==1221== 1,048,576 bytes in 1 block are definitely lost in loss record 1 of 1
  12. ==1221== at 0x4864DE4: malloc (in /usr/libexec/valgrind/vgpreload_memcheck-arm-linux.so)
  13. ==1221==
  14. ==1221== LEAK SUMMARY:
  15. ==1221== definitely lost: 1,048,576 bytes in 1 block
  16. ==1221== indirectly lost: 0 bytes in 0 blocks
  17. ==1221== possibly lost: 0 bytes in 0 blocks
  18. ==1221== still reachable: 0 bytes in 0 blocks
  19. ==1221== suppressed: 0 bytes in 0 blocks
  20. ==1221==
  21. ==1221== For lists of detected and suppressed errors, rerun with: -s
  22. ==1221== ERROR SUMMARY: 1 errors from 1 contexts (suppressed: 0 from 0)

Is it possible to get the source code line where the memory was allocated? If yes, where am I wrong?
是否有可能获取分配内存的源代码行?如果可以,我错在哪里?

英文:

I am using Valgrind, version 3.19.0 on an ARM platform.
I wrote a small program that hase a memory leak; here's the source:

  1. #include &lt;stdlib.h&gt;
  2. int main()
  3. {
  4. char* p = (char*)malloc(1024 * 1024);
  5. return 0;
  6. }

I compiled it with

> ```sh
> arm-buildroot-linux-gnueabi-gcc -g -O0 -o test test.c

Then run with Valgrind on my ARM machine:
> ```sh
> valgrind --leak-check=full --show-leak-kinds=all --track-origins=yes --verbose ./test

Looks like Valgrind successfully detect the leak, bu it gives no info about the source code. Here's the output:

  1. ==1221== Memcheck, a memory error detector
  2. ==1221== Copyright (C) 2002-2022, and GNU GPL&#39;d, by Julian Seward et al.
  3. ==1221== Using Valgrind-3.19.0 and LibVEX; rerun with -h for copyright info
  4. ==1221== Command: ./test
  5. ==1221==
  6. ==1221==
  7. ==1221== HEAP SUMMARY:
  8. ==1221== in use at exit: 1,048,576 bytes in 1 blocks
  9. ==1221== total heap usage: 2 allocs, 1 frees, 1,068,800 bytes allocated
  10. ==1221==
  11. ==1221== 1,048,576 bytes in 1 blocks are definitely lost in loss record 1 of 1
  12. ==1221== at 0x4864DE4: malloc (in /usr/libexec/valgrind/vgpreload_memcheck-arm-linux.so)
  13. ==1221==
  14. ==1221== LEAK SUMMARY:
  15. ==1221== definitely lost: 1,048,576 bytes in 1 blocks
  16. ==1221== indirectly lost: 0 bytes in 0 blocks
  17. ==1221== possibly lost: 0 bytes in 0 blocks
  18. ==1221== still reachable: 0 bytes in 0 blocks
  19. ==1221== suppressed: 0 bytes in 0 blocks
  20. ==1221==
  21. ==1221== For lists of detected and suppressed errors, rerun with: -s
  22. ==1221== ERROR SUMMARY: 1 errors from 1 contexts (suppressed: 0 from 0)

Is it possible to get the source code line where the memory was allocated? If yes, where am I wrong?

答案1

得分: 1

感谢phd的评论,我下载了Valgrind的最新版本,使用我的工具链进行了交叉编译,并将其复制到了我的目标机器上。新版本可以正确显示分配泄漏内存的源代码行。

英文:

Thanks to phd comment, I download the latest version of Valgrind, cross compiled it with my toolchain and copied it to my target machine. The newer version properly display the source code line where the leaked memory has been allocated

huangapple
  • 本文由 发表于 2023年6月8日 21:49:45
  • 转载请务必保留本文链接:https://go.coder-hub.com/76432559.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定