gpt4 book ai didi

c - 为什么会触发 SIGSEGV?

转载 作者:行者123 更新时间:2023-11-30 19:26:13 24 4
gpt4 key购买 nike

我有一个在ARM平台上运行的多线程程序。在其中一个线程中,我将调用 system() 来运行某些 shell 命令。最近,我发现有时候,由system() fork 的子进程会以SIGSEGV终止。

strace 显示子进程终止并显示以下消息。

1423872694.771573 set_robust_list(0xb5a90070, 12) = 0
1423872694.773834 rt_sigaction(SIGINT, {SIG_IGN, [], 0x4000000 /* SA_??? */}, NULL, 8) = 0
1423872694.774906 rt_sigaction(SIGQUIT, {SIG_IGN, [], 0x4000000 /* SA_??? */}, NULL, 8) = 0
1423872694.775973 rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
1423872694.776986 execve("/bin/sh", ["sh", "-c", "sync"], [/* 17 vars */]) = 0
1423872694.784928 brk(0) = 0xea000
1423872694.786133 uname({sys="Linux", node="localhost", ...}) = 0
1423872694.787440 access("/etc/ld.so.preload", R_OK) = -1 ENOENT (No such file or directory)
1423872694.788602 --- SIGSEGV {si_signo=SIGSEGV, si_code=SEGV_MAPERR, si_addr=0xe} ---
1423872694.789370 +++ killed by SIGSEGV +++

我得到了coredump文件并用gdb对其进行了分析,结果如下。看来在这种状态下不会发生段错误。您想告诉我为什么会触发 SIGSEGV,或者我在查找 SIGSEGV 原因时错过了什么吗?

Core was generated by `sh -c sync'.
Program terminated with signal 11, Segmentation fault.
#0 0x4d8f1008 in _dl_map_object (loader=0x4d912968, name=0xe1629 "libtinfo.so.5", type=<optimized out>, trace_mode=0, mode=0, nsid=0) at dl-load.c:2187
2187 dl-load.c: No such file or directory.
(gdb) bt
#0 0x4d8f1008 in _dl_map_object (loader=0x4d912968, name=0xe1629 "libtinfo.so.5", type=<optimized out>, trace_mode=0, mode=0, nsid=0) at dl-load.c:2187
#1 0x4d8f647c in openaux (a=0xbe89a99c) at dl-deps.c:64
#2 0x4d8f83cc in _dl_catch_error (objname=0x0, errstring=0x4d912880 <data.11735>, mallocedp=0xbe89a9b8, operate=0xbe89a9b4, args=0xbe89a99c) at dl-error.c:178
#3 0x4d8f6708 in _dl_map_object_deps (map=0x4d912968, preloads=<optimized out>, npreloads=<optimized out>, trace_mode=0, open_mode=0) at dl-deps.c:257
#4 0x4d8ebbb4 in dl_main (phdr=<optimized out>, phnum=1301358928, user_entry=0x1, auxv=0x4d912050 <_rtld_global>) at rtld.c:1939
#5 0x4d8fede8 in _dl_sysdep_start (start_argptr=<optimized out>, dl_main=0x4d8fede8 <_dl_sysdep_start+572>) at ../elf/dl-sysdep.c:244
#6 0x4d8ea0b8 in _dl_start_final (arg=0xbe89bda0, info=<optimized out>) at rtld.c:431
#7 0x4d8ea3b8 in _dl_start (arg=0x0) at rtld.c:659
#8 0x4d8e8e30 in _start () from /opt/windriver/wrlinux/5.0-digital-spear320-newpuppy/sysroots/digital_spear320-wrs-linux-gnueabi/lib/ld-linux.so.3
Backtrace stopped: frame did not save the PC
(gdb) info registers
r0 0x0 0
r1 0xe 14
r2 0x0 0
r3 0x4d911f30 1301356336
r4 0xe1629 923177
r5 0x0 0
r6 0x4d912968 1301358952
r7 0x4d912b00 1301359360
r8 0x1 1
r9 0x1 1
r10 0x0 0
r11 0x0 0
r12 0xbe89a72c 3196692268
sp 0xbe89a4e8 0xbe89a4e8
lr 0x2 2
pc 0x4d8f1008 0x4d8f1008 <_dl_map_object+672>
cpsr 0x20000010 536870928
(gdb) disassemble
0x4d8f0fd8 <+624>: ldr r1, [sp, #36] ; 0x24
0x4d8f0fdc <+628>: add r3, pc, r12
0x4d8f0fe0 <+632>: add r12, sp, #572 ; 0x23c
0x4d8f0fe4 <+636>: str r12, [sp]
0x4d8f0fe8 <+640>: add r12, sp, #56 ; 0x38
0x4d8f0fec <+644>: stmib sp, {r12, lr}
0x4d8f0ff0 <+648>: mov lr, #2
0x4d8f0ff4 <+652>: add r12, sp, #580 ; 0x244
0x4d8f0ff8 <+656>: add r3, r3, #24
0x4d8f0ffc <+660>: str lr, [sp, #12]
0x4d8f1000 <+664>: mov r0, r4
0x4d8f1004 <+668>: add lr, r12, #3
=> 0x4d8f1008 <+672>: str lr, [sp, #16]
0x4d8f100c <+676>: bl 0x4d8ee9d0 <open_path>
0x4d8f1010 <+680>: cmn r0, #1
0x4d8f1014 <+684>: mov r1, r0
0x4d8f1018 <+688>: movne r3, #0
0x4d8f101c <+692>: moveq r3, #1
0x4d8f1020 <+696>: tst r3, r8
0x4d8f1024 <+700>: bne 0x4d8f119c <_dl_map_object+1076>
(gdb) x/64a 0xbe89a4e8 - 32
0xbe89a4c8: 0x0 0x0 0x0 0xe1629
0xbe89a4d8: 0x0 0x4d912968 0x0 0xe1629
0xbe89a4e8: 0xbe89a724 0xbe89a520 0x4d912968 0x2
0xbe89a4f8: 0x0 0x0 0x0 0x0
0xbe89a508: 0x0 0xe 0x4d912968 0x0
0xbe89a518: 0x1 0x1 0x0 0x0
0xbe89a528: 0x0 0x0 0x0 0x0
0xbe89a538: 0x0 0x0 0x0 0x0
0xbe89a548: 0x0 0x0 0x0 0x0
0xbe89a558: 0x0 0x0 0x0 0x0
0xbe89a568: 0x0 0x0 0x0 0x0
0xbe89a578: 0x0 0x0 0x0 0x0
0xbe89a588: 0x0 0x0 0x0 0x0
0xbe89a598: 0x0 0x0 0x0 0x0
0xbe89a5a8: 0x0 0x0 0x0 0x0
0xbe89a5b8: 0x0 0x0 0x0 0x0
(gdb) info threads
Id Target Id Frame
* 1 LWP 289 0x4d8f1008 in _dl_map_object (loader=0x4d912968, name=0xe1629 "libtinfo.so.5", type=<optimized out>, trace_mode=0, mode=0, nsid=0) at dl-load.c:2187

最佳答案

Would you like to tell why the SIGSEGV is triggered?

您的 GLIBC 版本存在错误。

After I unset LD_LIBRARY_PATH, I can not reproduce this bug.

该错误存在于 GLIBC 处理 LD_LIBRARY_PATH 的某个地方。

您没有告诉您正在使用哪个版本的 GLIBC,因此很难判断这可能是哪个错误。也许this one

关于c - 为什么会触发 SIGSEGV?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57832620/

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