繁体   English   中英

OpenMP未初始化的值和Valgrind

[英]OpenMP Uninitialized values and Valgrind

我在使用Valgrind检查内存泄漏时遇到了一些问题(并且还了解了我在fprintf中遇到的段错误),但是似乎有些原因使用了一些未初始化的值,这些值不是我的代码产生的。 我是调试器调试的新手,所以我可能会缺少一些东西。

我知道Valgrind是不是舒适与我的默认GCC的OpenMP( http://valgrind.org/docs/manual/drd-manual.html#drd-manual.openmp ),但我使用它,compilimg我的代码以-pedantic -Wall -static -O0 -g -fopenmp我没有错误。

但是,在运行Valgrind时,

valgrind --leak-check=full --track-origins=yes --error-limit=no --log-file=./logfile ~/developing/trunk/gop.exe

我在日志文件中收到很多警告,从

==5944== Memcheck, a memory error detector
==5944== Copyright (C) 2002-2011, and GNU GPL'd, by Julian Seward et al.
==5944== Using Valgrind-3.7.0 and LibVEX; rerun with -h for copyright info
==5944== Command: /home/henrique/developing/trunk/gop.exe
==5944== Parent PID: 11534
==5944== 
==5944== Syscall param set_robust_list(head) points to uninitialised byte(s)
==5944==    at 0x4983DF: __pthread_initialize_minimal (nptl-init.c:369)
==5944==    by 0x498920: (below main) (libc-start.c:146)
==5944==  Address 0x4000bf0 is not stack'd, malloc'd or (recently) free'd
==5944==  Uninitialised value was created
==5944==    at 0x513A6A: brk (brk.c:32)
==5944==    by 0x4ED4EB: sbrk (sbrk.c:54)
==5944==    by 0x498C13: __libc_setup_tls (libc-tls.c:150)
==5944==    by 0x498366: __pthread_initialize_minimal (nptl-init.c:296)
==5944==    by 0x498920: (below main) (libc-start.c:146)

然后收到与以下警告类似的大量警告(数千!)

==5944== Conditional jump or move depends on uninitialised value(s)
==5944==    at 0x4EF546: __linkin_atfork (register-atfork.c:119)
==5944==    by 0x4BA5D3: ptmalloc_init (arena.c:388)
==5944==    by 0x4BB283: malloc_hook_ini (hooks.c:32)
==5944==    by 0x51842B: _dl_init_paths (dl-load.c:732)
==5944==    by 0x4F097A: _dl_non_dynamic_init (dl-support.c:268)
==5944==    by 0x4F1352: __libc_init_first (init-first.c:83)
==5944==    by 0x49895B: (below main) (libc-start.c:165)
==5944==  Uninitialised value was created
==5944==    at 0x513A6A: brk (brk.c:32)
==5944==    by 0x4ED4EB: sbrk (sbrk.c:54)
==5944==    by 0x498C13: __libc_setup_tls (libc-tls.c:150)
==5944==    by 0x498366: __pthread_initialize_minimal (nptl-init.c:296)
==5944==    by 0x498920: (below main) (libc-start.c:146)

在编译或运行Valgrind时是否缺少某些内容? 还是我的代码确实存在所有这些错误?

非常感谢你!

某些库确实有很多小警告,例如您正在显示的警告。 我认为它们不是从您的代码中看到它们出现的文件名而来。

您将不得不在其他地方查找段错误。 尝试使用gdb运行它,查看它的停止位置并在错误周围打印值以查看发生了什么。

希望能帮助到你 :)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM