Index: ELF/MarkLive.cpp =================================================================== --- ELF/MarkLive.cpp +++ ELF/MarkLive.cpp @@ -81,13 +81,6 @@ template static void forEachSuccessor(InputSection &Sec, std::function)> Fn) { - // Skip over discarded sections. This in theory shouldn't happen, because - // the ELF spec doesn't allow a relocation to point to a deduplicated - // COMDAT section directly. Unfortunately this happens in practice (e.g. - // .eh_frame) so we need to add a check. - if (&Sec == &InputSection::Discarded) - return; - ELFFile &Obj = Sec.getFile()->getObj(); for (const typename ELFT::Shdr *RelSec : Sec.RelocSections) { if (RelSec->sh_type == SHT_RELA) { @@ -184,8 +177,8 @@ return true; return S.startswith(".ctors") || S.startswith(".dtors") || - S.startswith(".init") || S.startswith(".fini") || - S.startswith(".jcr"); + S.startswith(".debug") || S.startswith(".init") || + S.startswith(".fini") || S.startswith(".jcr"); } } @@ -196,7 +189,11 @@ SmallVector *, 256> Q; auto Enqueue = [&](ResolvedReloc R) { - if (!R.Sec) + // Skip over discarded sections. This in theory shouldn't happen, because + // the ELF spec doesn't allow a relocation to point to a deduplicated + // COMDAT section directly. Unfortunately this happens in practice (e.g. + // .eh_frame) so we need to add a check. + if (!R.Sec || R.Sec == &InputSection::Discarded) return; // Usually, a whole section is marked as live or dead, but in mergeable Index: test/ELF/linkerscript/Inputs/comdat-gc.s =================================================================== --- test/ELF/linkerscript/Inputs/comdat-gc.s +++ test/ELF/linkerscript/Inputs/comdat-gc.s @@ -0,0 +1,5 @@ +.section .text._Z3fooIiEvv,"axG",@progbits,_Z3fooIiEvv,comdat + ret + +.section .debug_lines,"",@progbits + .quad .text._Z3fooIiEvv Index: test/ELF/linkerscript/comdat-gc.s =================================================================== --- test/ELF/linkerscript/comdat-gc.s +++ test/ELF/linkerscript/comdat-gc.s @@ -0,0 +1,12 @@ +# REQUIRES: x86 + +# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t +# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %p/Inputs/comdat-gc.s -o %t1 +# RUN: echo "SECTIONS { .text : { *(.text*) } }" > %t.script +# RUN: ld.lld --gc-sections --script %t.script %t %t1 -o %t2 +# RUN: llvm-readobj -sections -symbols %t2 | FileCheck -check-prefix=GC1 %s + +# GC1: Name: .debug_lines + +.section .text._Z3fooIiEvv,"axG",@progbits,_Z3fooIiEvv,comdat + ret