https://llvm.org/bugs/show_bug.cgi?id=25915
Bug ID: 25915 Summary: rL256003 breaks LTO with debug info Product: lld Version: unspecified Hardware: PC OS: Linux Status: NEW Severity: normal Priority: P Component: All Bugs Assignee: unassignedb...@nondot.org Reporter: kra...@google.com CC: llvm-bugs@lists.llvm.org Classification: Unclassified Consider the following program: $ cat lala.cc const char lala[] = { 0 }; Let's compile it with -flto and -g, and link using Gold plugin: $ /usr/local/google/home/krasin/src/llvm.org/release-build/bin/clang++ -flto -g -fuse-ld=gold -o lala lala.cc clang-3.8: error: unable to execute command: Segmentation fault (core dumped) clang-3.8: error: linker command failed due to signal (use -v to see invocation) Gold under gdb: Program received signal SIGSEGV, Segmentation fault. (anonymous namespace)::IRLinker::findNeededSubprograms (this=this@entry=0x7fffffff6350, ValueMap=...) at /usr/local/google/home/krasin/src/llvm.org/llvm/lib/Linker/IRMover.cpp:1196 1196 for (const Metadata *Op : CU->getSubprograms()->operands()) { (gdb) bt #0 (anonymous namespace)::IRLinker::findNeededSubprograms (this=this@entry=0x7fffffff6350, ValueMap=...) at /usr/local/google/home/krasin/src/llvm.org/llvm/lib/Linker/IRMover.cpp:1196 #1 0x00007ffff454e361 in linkNamedMDNodes (this=0x7fffffff6350) at /usr/local/google/home/krasin/src/llvm.org/llvm/lib/Linker/IRMover.cpp:1250 #2 run (this=0x7fffffff6350) at /usr/local/google/home/krasin/src/llvm.org/llvm/lib/Linker/IRMover.cpp:1520 #3 llvm::IRMover::move(llvm::Module&, llvm::ArrayRef<llvm::GlobalValue*>, std::function<void (llvm::GlobalValue&, std::function<void (llvm::GlobalValue&)>)>, llvm::DenseMap<unsigned int, llvm::MDNode*, llvm::DenseMapInfo<unsigned int>, llvm::detail::DenseMapPair<unsigned int, llvm::MDNode*> >*, bool) (this=this@entry=0x7fffffff6a30, Src=..., ValuesToLink=..., AddLazyFor=..., ValIDToTempMDMap=ValIDToTempMDMap@entry=0x0, IsMetadataLinkingPostpass=IsMetadataLinkingPostpass@entry=false) at /usr/local/google/home/krasin/src/llvm.org/llvm/lib/Linker/IRMover.cpp:1654 #4 0x00007ffff3be433d in allSymbolsReadHook (ApiFile=ApiFile@entry=0x0) at /usr/local/google/home/krasin/src/llvm.org/llvm/tools/gold/gold-plugin.cpp:910 #5 0x00007ffff3be66ab in all_symbols_read_hook () at /usr/local/google/home/krasin/src/llvm.org/llvm/tools/gold/gold-plugin.cpp:955 #6 0x00000000004d5aef in ?? () #7 0x00000000004d5c24 in ?? () #8 0x0000000000516c65 in ?? () #9 0x0000000000516fca in ?? () #10 0x0000000000404f32 in ?? () #11 0x00007ffff7313ec5 in __libc_start_main (main=0x404a80, argc=37, argv=0x7fffffffd708, init=<optimized out>, fini=<optimized out>, rtld_fini=<optimized out>, stack_end=0x7fffffffd6f8) at libc-start.c:287 #12 0x0000000000405e41 in ?? () This is introduced in http://reviews.llvm.org/rL256003 and the immediate problem is in the line IRMover.cpp:1197 that makes an assumption that CU->getSubprograms() will always return a non-NULL value. This was initially discovered on one of Chromium buildbots, see https://crbug.com/570694#c14 -- You are receiving this mail because: You are on the CC list for the bug.
_______________________________________________ llvm-bugs mailing list llvm-bugs@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-bugs