Index: ELF/Driver.cpp =================================================================== --- ELF/Driver.cpp +++ ELF/Driver.cpp @@ -1117,6 +1117,14 @@ for (InputSectionBase *S : F->getSections()) InputSections.push_back(cast(S)); + // When --strip-debug/--strip-all is given we want to remove debug sections + // from output, but we can not just discard them because use debug information + // for building error messages. + if (Config->Strip != StripPolicy::None) + llvm::erase_if(InputSections, [](InputSectionBase *S) { + return S->Name.startswith(".debug") || S->Name.startswith(".zdebug"); + }); + Config->EFlags = Target->calcEFlags(); // This adds a .comment section containing a version string. We have to add it Index: ELF/InputFiles.cpp =================================================================== --- ELF/InputFiles.cpp +++ ELF/InputFiles.cpp @@ -537,10 +537,6 @@ return &InputSection::Discarded; } - if (Config->Strip != StripPolicy::None && - (Name.startswith(".debug") || Name.startswith(".zdebug"))) - return &InputSection::Discarded; - // The linkonce feature is a sort of proto-comdat. Some glibc i386 object // files contain definitions of symbol "__x86.get_pc_thunk.bx" in linkonce // sections. Drop those sections to avoid duplicate symbol errors. Index: test/ELF/conflict-debug-variable.s =================================================================== --- test/ELF/conflict-debug-variable.s +++ test/ELF/conflict-debug-variable.s @@ -30,6 +30,9 @@ # CHECK-NEXT: >>> defined at 1.c:1 # CHECK-NEXT: >>> {{.*}}:(.bss+0x0) +## Check that stripping debug sections does not break error reporting. +# RUN: not ld.lld --strip-debug %t.o %t.o -o %t 2>&1 | FileCheck %s + # Used reduced output from following code and gcc 7.1.0 # to produce this input file: # Source (1.c):