gpt4 book ai didi

c++ - 使用 gcc 的线程清理器在启动时会产生各种错误

转载 作者:太空宇宙 更新时间:2023-11-04 04:28:51 24 4
gpt4 key购买 nike

我有一些奇怪的多线程错误,所以我想使用 gcc thread sanitizer 来找到它们。但是,当我使用 -sanitize=thread 编译时,生成的二进制段错误立即与以下堆栈跟踪:

#0  0x0000000000000000 in ?? ()
#1 0x00007ffff5911cee in ?? () from /usr/lib/x86_64-linux-gnu/libtsan.so.0
#2 0x00007ffff593408d in ?? () from /usr/lib/x86_64-linux-gnu/libtsan.so.0
#3 0x00007ffff58eeb98 in ?? () from /usr/lib/x86_64-linux-gnu/libtsan.so.0
#4 0x00007ffff58ef0ce in __interceptor___cxa_atexit ()
from /usr/lib/x86_64-linux-gnu/libtsan.so.0
#5 0x00007ffff55d1e56 in ?? () from /usr/lib/x86_64-linux-gnu/libstdc++.so.6
#6 0x00007ffff7de74ea in call_init (l=<optimised out>, argc=argc@entry=1,
argv=argv@entry=0x7fffffffdeb8, env=env@entry=0x7fffffffdec8)
at dl-init.c:72
#7 0x00007ffff7de75fb in call_init (env=0x7fffffffdec8, argv=0x7fffffffdeb8,
argc=1, l=<optimised out>) at dl-init.c:30
#8 _dl_init (main_map=0x7ffff7ffe168, argc=1, argv=0x7fffffffdeb8,
env=0x7fffffffdec8) at dl-init.c:120
#9 0x00007ffff7dd7cfa in _dl_start_user () from /lib64/ld-linux-x86-64.so.2
#10 0x0000000000000001 in ?? ()
#11 0x00007fffffffe22b in ?? ()
#12 0x0000000000000000 in ?? ()

我尝试添加 -static-libtsan 属性,但现在出现以下错误:

FATAL: ThreadSanitizer CHECK failed: ../../../../src/libsanitizer/sanitizer_common/sanitizer_allocator.h:1203 "((IsAligned(p, page_size_))) != (0)" (0x0, 0x0)
#0 __tsan::TsanCheckFailed(char const*, int, char const*, unsigned long long, unsigned long long) <null> (sql+0x0000004aeb53)
#1 __tsan::TsanCheckFailed(char const*, int, char const*, unsigned long long, unsigned long long) <null> (sql+0x0000004aeb5b)
#2 __sanitizer::CheckFailed(char const*, int, char const*, unsigned long long, unsigned long long) <null> (sql+0x0000004b3af3)
#3 __tsan::user_free(__tsan::ThreadState*, unsigned long, void*, bool) <null> (sql+0x00000049e6fc)
#4 operator delete(void*) <null> (sql+0x00000045f6ec)
#5 __static_initialization_and_destruction_0(int, int) [clone .constprop.123] <null> (sql+0x00000044a4ab)
#6 __libc_csu_init <null> (sql+0x00000254468c)
#7 __libc_start_main <null> (libc.so.6+0x0000000207be)
#8 _start <null> (sql+0x000000459e18)

我该如何解决这个问题?我在这里做错了什么?

最佳答案

我没有用过 TSAN w/gcc,所以帮不上忙,但你可能想用 clang ( https://clang.llvm.org/ ) 试一试。由于 TSAN 是 clang 的一部分,因此错误往​​往会首先在那里得到修复。

如果您在构建 clang 时需要帮助,我还写了一篇可能有用的文章:http://btorpey.github.io/blog/2015/01/02/building-clang/

关于c++ - 使用 gcc 的线程清理器在启动时会产生各种错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38664803/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com