Прежде всего, я хочу извиниться за то, что не смог сузить проблему настолько, чтобы поделиться короткой программой, воспроизводящей ошибку.
Вызов внешней библиотеки (FUSE) strncpy
"случайно" перезаписывает shared_ptr<mutex>
в моем коде, что вызывает ошибку сегментации, когда я пытаюсь заблокировать этот мьютекс. Я запустил свою программу с помощью valgrind, и она не обнаружила никаких ошибок памяти (флаги valgrind ниже). Когда я запускаю свой код в gdb и устанавливаю точку наблюдения на этом shared_ptr
, он прерывается при вызове strncpy. gdb говорит, что все параметры strncpy
(dest, src и nbytes) были «оптимизированы», что заставляет меня думать, что для этого вызова используется неинициализированная память. Я правильно интерпретирую это? Любая идея, что может быть причиной?
Вот трассировка стека из gdb при перезаписи указателя:
#0 __strncpy_ssse3 () at ../sysdeps/x86_64/multiarch/strcpy-ssse3.S:2482
#1 0x0000003245809094 in strncpy (__len=<optimized out>, __src=<optimized out>, __dest=<optimized out>) at /usr/include/bits/string3.h:120
#2 add_name (buf=<optimized out>, bufsize=<optimized out>, s=<optimized out>, name=<optimized out>) at fuse.c:907
#3 0x000000324580997c in try_get_path (f=<optimized out>, nodeid=<optimized out>, name=<optimized out>, path=<optimized out>, wnodep=<optimized out>, need_lock=<optimized out>) at fuse.c:956
#4 0x000000324580a281 in get_path_common (f=<optimized out>, nodeid=<optimized out>, name=<optimized out>, path=<optimized out>, wnode=<optimized out>) at fuse.c:1152
#5 0x0000003245812432 in fuse_lib_unlink (req=<optimized out>, parent=<optimized out>, name=<optimized out>) at fuse.c:1198
#6 0x0000003245817057 in fuse_ll_process_buf (data=0x6f5650, buf=0x7fffffffd850, ch=<optimized out>) at fuse_lowlevel.c:2441
#7 0x000000324581388f in fuse_session_loop (se=0x6f8410) at fuse_loop.c:40
#8 0x000000324580b698 in fuse_loop (f=<optimized out>) at fuse.c:4309
#9 0x000000324581bb8f in fuse_main_common (argc=<optimized out>, argv=<optimized out>, op=<optimized out>, op_size=<optimized out>, user_data=<optimized out>, compat=<optimized out>) at helper.c:355
#10 0x000000000046f1b6 in main (argc=4, argv=0x7fffffffdec8) at ../src/fuse.cpp:100
Вот аргументы, с которыми я запустил valgrind:
valgrind --tool=memcheck --leak-check=yes --show-reachable=yes --num-callers=20 --track-fds=yes