Perl进程陷入«;***glibc检测到***perl:损坏的双链接列表:0x0000000001474b40***»;-我怎样才能让它终止?

Perl进程陷入«;***glibc检测到***perl:损坏的双链接列表:0x0000000001474b40***»;-我怎样才能让它终止?,c,linux,perl,unix,glibc,C,Linux,Perl,Unix,Glibc,我一直在尝试用Perl 5和XML::LibXML(我现在维护)调试内存损坏问题。现在我得到的是: shlomif@lap:~/progs/perl/cpan/XML/LibXML/bugs/perl-xml-libxml-bugs/XML-LibXML-reader-segfault$ make test XML_CATALOG_FILES="`pwd`/sgml-lib/catalog.xml" perl find_ascii_quotes.pl index.html *** glibc d

我一直在尝试用Perl 5和XML::LibXML(我现在维护)调试内存损坏问题。现在我得到的是:

shlomif@lap:~/progs/perl/cpan/XML/LibXML/bugs/perl-xml-libxml-bugs/XML-LibXML-reader-segfault$ make test
XML_CATALOG_FILES="`pwd`/sgml-lib/catalog.xml" perl find_ascii_quotes.pl index.html
*** glibc detected *** perl: corrupted double-linked list: 0x0000000001474b40 ***
^Cmake: *** [test] Interrupt
然后,Perl进程被卡住,无法返回shell。问题是,Perl进程停止的事实中断了我的流程,我正在寻找一种方法,让进程崩溃或其他什么,而不是挂在那里。GDB报告如下。您可以在中找到有问题的代码(只需运行“make test”),我正在x86-64上进行Mandriva Linux开发(Cooker)

ader-segfault$ gdb --command=cmds.gdb /usr/bin/perl
GNU gdb (GDB) 7.1-5 (Mandriva Linux release 2011.0)
Copyright (C) 2010 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.  Type "show copying"
and "show warranty" for details.
This GDB was configured as "x86_64-mandriva-linux-gnu".
For bug reporting instructions, please see:
<http://www.gnu.org/software/gdb/bugs/>...
Reading symbols from /usr/bin/perl...
warning: the debug information found in "/usr/lib/debug//usr/bin/perl5.12.3.debug" does not match "/usr/bin/perl" (CRC mismatch).


warning: the debug information found in "/usr/lib/debug/usr/bin/perl5.12.3.debug" does not match "/usr/bin/perl" (CRC mismatch).

(no debugging symbols found)...done.
warning: the debug information found in "/usr/lib/debug//usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so.debug" does not match "/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so" (CRC mismatch).

warning: the debug information found in "/usr/lib/debug/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so.debug" does not match "/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so" (CRC mismatch).

[Thread debugging using libthread_db enabled]
warning: the debug information found in "/usr/lib/debug//usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Encode/Encode.so.debug" does not match "/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Encode/Encode.so" (CRC mismatch).

warning: the debug information found in "/usr/lib/debug/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Encode/Encode.so.debug" does not match "/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Encode/Encode.so" (CRC mismatch).

warning: the debug information found in "/usr/lib/debug//usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Data/Dumper/Dumper.so.debug" does not match "/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Data/Dumper/Dumper.so" (CRC mismatch).

warning: the debug information found in "/usr/lib/debug/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Data/Dumper/Dumper.so.debug" does not match "/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Data/Dumper/Dumper.so" (CRC mismatch).

warning: the debug information found in "/usr/lib/debug//usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/IO/IO.so.debug" does not match "/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/IO/IO.so" (CRC mismatch).

warning: the debug information found in "/usr/lib/debug/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/IO/IO.so.debug" does not match "/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/IO/IO.so" (CRC mismatch).

warning: the debug information found in "/usr/lib/debug//usr/lib/perl5/vendor_perl/5.12.3/x86_64-linux-thread-multi/auto/XML/LibXML/LibXML.so.debug" does not match "/usr/lib/perl5/vendor_perl/5.12.3/x86_64-linux-thread-multi/auto/XML/LibXML/LibXML.so" (CRC mismatch).

warning: the debug information found in "/usr/lib/debug/usr/lib/perl5/vendor_perl/5.12.3/x86_64-linux-thread-multi/auto/XML/LibXML/LibXML.so.debug" does not match "/usr/lib/perl5/vendor_perl/5.12.3/x86_64-linux-thread-multi/auto/XML/LibXML/LibXML.so" (CRC mismatch).

*** glibc detected *** /usr/bin/perl: corrupted double-linked list: 0x0000000000b83440 ***
^C
Program received signal SIGINT, Interrupt.
0x00007ffff6abe12e in __lll_lock_wait_private () from /lib64/libc.so.6
Missing debug package(s), you should install: perl-debug-5.12.3-8.x86_64
(gdb) bt
#0  0x00007ffff6abe12e in __lll_lock_wait_private () from /lib64/libc.so.6
#1  0x00007ffff6a4f7a1 in _L_lock_9854 () from /lib64/libc.so.6
#2  0x00007ffff6a4d6eb in malloc () from /lib64/libc.so.6
#3  0x00007ffff6a43d6d in __libc_message () from /lib64/libc.so.6
#4  0x00007ffff6a49bfa in malloc_printerr () from /lib64/libc.so.6
#5  0x00007ffff6a49f38 in malloc_consolidate.part.3 () from /lib64/libc.so.6
#6  0x00007ffff6a4a749 in _int_free () from /lib64/libc.so.6
#7  0x00007ffff4e8b0e0 in xmlHashFree__internal_alias (table=0xb2db40,
    f=0x7ffff4e98e00 <xmlFreeAttribute>) at hash.c:324
#8  0x00007ffff4e82e42 in xmlFreeDtd__internal_alias (cur=0x633310)
    at tree.c:1126
#9  0x00007ffff4e8259a in xmlFreeDoc__internal_alias (cur=0x635100)
    at tree.c:1227
#10 0x00007ffff51e75a5 in PmmREFCNT_dec ()
   from /usr/lib/perl5/vendor_perl/5.12.3/x86_64-linux-thread-multi/auto/XML/LibXML/LibXML.so
#11 0x00007ffff51c4f65 in XS_XML__LibXML__Node_DESTROY ()
   from /usr/lib/perl5/vendor_perl/5.12.3/x86_64-linux-thread-multi/auto/XML/LibXML/LibXML.so
#12 0x00007ffff7b1d60d in Perl_pp_entersub ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#13 0x00007ffff7ab9242 in Perl_call_sv ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
---Type <return> to continue, or q <return> to quit---
#14 0x00007ffff7b22cfa in Perl_sv_clear ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#15 0x00007ffff7b23552 in Perl_sv_free2 ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#16 0x00007ffff7b2314d in Perl_sv_clear ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#17 0x00007ffff7b23552 in Perl_sv_free2 ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#18 0x00007ffff51a6ad9 in XS_XML__LibXML__Reader__DESTROY ()
   from /usr/lib/perl5/vendor_perl/5.12.3/x86_64-linux-thread-multi/auto/XML/LibXML/LibXML.so
#19 0x00007ffff7b1d60d in Perl_pp_entersub ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#20 0x00007ffff7b14d70 in Perl_runops_standard ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#21 0x00007ffff7ab9083 in Perl_call_sv ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#22 0x00007ffff7b22cfa in Perl_sv_clear ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#23 0x00007ffff7b23552 in Perl_sv_free2 ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#24 0x00007ffff7b4a45f in Perl_leave_scope ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
---Type <return> to continue, or q <return> to quit---
#25 0x00007ffff7b15ad2 in Perl_pp_unstack ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#26 0x00007ffff7b14d70 in Perl_runops_standard ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#27 0x00007ffff7abed6e in perl_run ()
   from /usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#28 0x0000000000400e29 in main ()
(gdb)
ader segfault$gdb--command=cmds.gdb/usr/bin/perl
GNU gdb(gdb)7.1-5(Mandriva Linux 2011.0版)
版权所有(C)2010免费软件基金会。
许可证GPLv3+:GNU GPL版本3或更高版本
这是自由软件:您可以自由更改和重新发布它。
在法律允许的范围内,不存在任何担保。键入“显示复制”
和“显示保修”了解详细信息。
此GDB配置为“x86_64-mandriva-linux-gnu”。
有关错误报告说明,请参阅:
...
正在从/usr/bin/perl读取符号。。。
警告:在“/usr/lib/debug//usr/bin/perl5.12.3.debug”中找到的调试信息与“/usr/bin/perl”不匹配(CRC不匹配)。
警告:在“/usr/lib/debug/usr/bin/perl5.12.3.debug”中找到的调试信息与“/usr/bin/perl”不匹配(CRC不匹配)。
(未找到调试符号)…完成。
警告:在“/usr/lib/debug//usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so.debug”中找到的调试信息不匹配“/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so”(CRC不匹配)。
警告:“/usr/lib/debug/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so.debug”中的调试信息不匹配“/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so”(CRC不匹配)。
[已启用使用libthread_db的线程调试]
警告:在“/usr/lib/debug//usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Encode/Encode.so.debug”中找到的调试信息不匹配“/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Encode/Encode.so”(CRC不匹配)。
警告:在“/usr/lib/debug/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Encode/Encode.so.debug”中找到的调试信息不匹配“/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Encode/Encode.so”(CRC不匹配)。
警告:在“/usr/lib/debug//usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Data/Dumper/Dumper.so.debug”中找到的调试信息不匹配“/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Data/Dumper/Dumper.so”(CRC不匹配)。
警告:在“/usr/lib/debug/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Data/Dumper/Dumper.so.debug”中找到的调试信息不匹配“/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/Data/Dumper/Dumper.so”(CRC不匹配)。
警告:在“/usr/lib/debug//usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/IO/IO.so.debug”中找到的调试信息不匹配“/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/IO.so”(CRC不匹配)。
警告:“/usr/lib/debug/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/IO/IO.so.debug”中的调试信息与“/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/auto/IO.so”不匹配(CRC不匹配)。
警告:“/usr/lib/debug//usr/lib/perl5/vendor_perl/5.12.3/x86_64-linux-thread-multi/auto/XML/LibXML/LibXML.so.debug”中的调试信息与“/usr/lib/perl5/vendor_perl/5.12.3/x86_64-linux-thread-multi/auto/XML/LibXML/LibXML.so”不匹配(CRC不匹配)。
警告:“/usr/lib/debug/usr/lib/perl5/vendor_perl/5.12.3/x86_64-linux-thread-multi/auto/XML/LibXML/LibXML.so.debug”中的调试信息不匹配“/usr/lib/perl5/vendor_perl/5.12.3/x86_64-linux-thread-multi/auto/XML/LibXML/LibXML.so”(CRC不匹配)。
***glibc检测到***/usr/bin/perl:已损坏的双链接列表:0x0000000000b83440***
^C
程序收到信号SIGINT,中断。
0x00007FF6ABE12E位于/lib64/libc.so.6中的
缺少调试包,应安装:perl-debug-5.12.3-8.x86_64
(gdb)英国电信
#0 0x00007FF6ABE12E位于/lib64/libc.so.6中的uu lll_lock_wait_private()中
#1 0x00007FF6A4F7A1位于/lib64/libc.so.6的_L_lock_9854()中
#来自/lib64/libc.so.6的malloc()中的2 0x00007FF6A4D6EB
#来自/lib64/libc.so.6的消息()中的0x00007FF6A43D6D
#来自/lib64/libc.so.6的malloc_printerr()中的4 0x00007FF6A49BFA
#来自/lib64/libc.so.6的malloc_consolidate.part.3()中的5 0x00007FF6A49F38
#6 0x00007FF6A4A749 in_int_free()来自/lib64/libc.so.6
#xmlHashFree_uu内部_u别名中的7 0x00007ffff4e8b0e0(表=0xb2db40,
f=0x7ffff4e98e00)在哈希处。c:324
#xmlFreeDtd_uu内部_u别名中的8 0x00007ffff4e82e42(cur=0x633310)
在树上。c:1126
#xmlFreeDoc_uu内部_u别名中的9 0x00007ffff4e8259a(cur=0x635100)
在树上。c:1227
#PmmREFCNT_dec()中的10 0x00007ffff51e75a5
来自/usr/lib/perl5/vendor_perl/5.12.3/x86_64-linux-thread-multi/auto/XML/LibXML/LibXML.so
#XS_XML_uulibXML_uunode_udestroy()中的11 0x00007ffff51c4f65
来自/usr/lib/perl5/vendor_perl/5.12.3/x86_64-linux-thread-multi/auto/XML/LibXML/LibXML.so
#Perl_pp_entersub()中的12 0x00007FF7B1D60D
来自/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#Perl_call_sv()中的13 0x00007ffff7ab9242
来自/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
---键入以继续,或键入q以退出---
#Perl_sv_clear中的14 0x00007FF7B22CFA()
来自/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#Perl_sv_free2()中的15 0x00007FF7B23552
来自/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#Perl_sv_clear()中的16 0x00007FF7B2314D
来自/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#Perl_sv_free2()中的17 0x00007FF7B23552
来自/usr/lib/perl5/5.12.3/x86_64-linux-thread-multi/CORE/libperl.so
#18