Index: ELF/MarkLive.cpp =================================================================== --- ELF/MarkLive.cpp +++ ELF/MarkLive.cpp @@ -166,8 +166,9 @@ scanEhFrameSection(EH, EObj.rels(EH.RelocSection), Enqueue); } -// Sections listed below are special because they are used by the loader -// just by being in an ELF file. They should not be garbage-collected. +// We do not garbage-collect two types of sections: +// 1) Sections used by the loader (.init, .fini, .ctors, .dtors, .jcr) +// 2) Not allocatable sections which typically contain debugging information template static bool isReserved(InputSectionBase *Sec) { switch (Sec->getSectionHdr()->sh_type) { case SHT_FINI_ARRAY: @@ -183,7 +184,8 @@ if (isValidCIdentifier(S)) return true; - return S.startswith(".ctors") || S.startswith(".dtors") || + bool IsAllocSec = Sec->getSectionHdr()->sh_flags & SHF_ALLOC; + return !IsAllocSec || S.startswith(".ctors") || S.startswith(".dtors") || S.startswith(".init") || S.startswith(".fini") || S.startswith(".jcr"); } Index: test/ELF/gc-sections.s =================================================================== --- test/ELF/gc-sections.s +++ test/ELF/gc-sections.s @@ -14,6 +14,8 @@ # NOGC: Name: .dtors # NOGC: Name: .init # NOGC: Name: .fini +# NOGC: Name: .debug_pubtypes +# NOGC: Name: .comment # NOGC: Name: a # NOGC: Name: b # NOGC: Name: c @@ -29,6 +31,8 @@ # GC1: Name: .dtors # GC1: Name: .init # GC1: Name: .fini +# GC1: Name: .debug_pubtypes +# GC1: Name: .comment # GC1: Name: a # GC1: Name: b # GC1: Name: c @@ -44,6 +48,8 @@ # GC2: Name: .dtors # GC2: Name: .init # GC2: Name: .fini +# GC2: Name: .debug_pubtypes +# GC2: Name: .comment # GC2: Name: a # GC2: Name: b # GC2: Name: c @@ -100,3 +106,9 @@ .section .eh_frame,"a",@unwind .quad 0 + +.section .debug_pubtypes,"",@progbits + .quad 0 + +.section .comment,"MS",@progbits,8 + .quad 0