__lll_unlock_wake_private中的SIGSEGV

时间:2017-02-13 02:15:02

标签: segmentation-fault gdb

当我使用函数fread时,程序会在__lll_unlock_wake_private获取sigsegv时出错,gdb消息如下:

(gdb) bt
#0  0x00000000 in ?? ()          
#1  0x009b77b6 in __lll_unlock_wake_private () from /lib/libc.so.6         
#2  0x00931c3b in _L_unlock_134 () from /lib/libc.so.6                   
#3  0x00931bd8 in fread () from /lib/libc.so.6              
#4  0x08049654 in init_global_list () at main.c:235                    
#5  0x0804b4e9 in init_prog () at main.c:1085                  
#6  0x0804c53f in main (argc=1, argv=0xf0) at main.c:1591                   

我想知道函数__lll_unlock_wake_private是如何工作的?

1 个答案:

答案 0 :(得分:0)

  

我想知道函数__lll_unlock_wake_private是如何工作的?

您可以看到其来源here

但您获得SIGSEGV的最可能原因是您使用fread流参数调用NULL

如果您执行以下gdb命令:frame 4list,您应该能够看到呼叫网站,并查看您传递到fread的值。