Index: lld/trunk/ELF/Config.h =================================================================== --- lld/trunk/ELF/Config.h +++ lld/trunk/ELF/Config.h @@ -112,6 +112,7 @@ bool AsNeeded = false; bool Bsymbolic; bool BsymbolicFunctions; + bool CheckSections; bool CompressDebugSections; bool DefineCommon; bool Demangle = true; Index: lld/trunk/ELF/Driver.cpp =================================================================== --- lld/trunk/ELF/Driver.cpp +++ lld/trunk/ELF/Driver.cpp @@ -600,6 +600,8 @@ Config->AuxiliaryList = args::getStrings(Args, OPT_auxiliary); Config->Bsymbolic = Args.hasArg(OPT_Bsymbolic); Config->BsymbolicFunctions = Args.hasArg(OPT_Bsymbolic_functions); + Config->CheckSections = + Args.hasFlag(OPT_check_sections, OPT_no_check_sections, true); Config->Chroot = Args.getLastArgValue(OPT_chroot); Config->CompressDebugSections = getCompressDebugSections(Args); Config->DefineCommon = Args.hasFlag(OPT_define_common, OPT_no_define_common, Index: lld/trunk/ELF/Options.td =================================================================== --- lld/trunk/ELF/Options.td +++ lld/trunk/ELF/Options.td @@ -31,6 +31,10 @@ def build_id_eq: J<"build-id=">, HelpText<"Generate build ID note">; +defm check_sections : B<"check-sections", + "Check section addresses for overlaps", + "Do not check section addresses for overlaps">; + defm compress_debug_sections : Eq<"compress-debug-sections">, HelpText<"Compress DWARF debug sections">; Index: lld/trunk/ELF/Writer.cpp =================================================================== --- lld/trunk/ELF/Writer.cpp +++ lld/trunk/ELF/Writer.cpp @@ -455,7 +455,8 @@ Sec->Addr = 0; } - checkNoOverlappingSections(); + if (Config->CheckSections) + checkNoOverlappingSections(); // It does not make sense try to open the file if we have error already. if (errorCount()) Index: lld/trunk/test/ELF/linkerscript/overlapping-sections.s =================================================================== --- lld/trunk/test/ELF/linkerscript/overlapping-sections.s +++ lld/trunk/test/ELF/linkerscript/overlapping-sections.s @@ -66,8 +66,10 @@ # LMA-OVERLAP-ERR-NEXT: >>> .sec1 range is [0x8000 -> 0x80FF] # LMA-OVERLAP-ERR-NEXT: >>> .sec2 range is [0x8080 -> 0x817F] -# check that we create the expected binary with --noinhibit-exec: +# Check that we create the expected binary with --noinhibit-exec or --no-check-sections: # RUN: ld.lld -o %t.so --script %t-lma.script %t.o -shared --noinhibit-exec +# RUN: ld.lld -o %t.so --script %t-lma.script %t.o -shared --no-check-sections +# RUN: ld.lld -o %t.so --script %t-lma.script %t.o -shared --check-sections --no-check-sections # Verify that the .sec2 was indeed placed in a PT_LOAD where the PhysAddr # overlaps with where .sec1 is loaded: