Index: lld/trunk/ELF/LinkerScript.cpp =================================================================== --- lld/trunk/ELF/LinkerScript.cpp +++ lld/trunk/ELF/LinkerScript.cpp @@ -772,6 +772,14 @@ if ((sec->flags & SHF_ALLOC) && sec->addrExpr) setDot(sec->addrExpr, sec->location, false); + // If the address of the section has been moved forward by an explicit + // expression so that it now starts past the current curPos of the enclosing + // region, we need to expand the current region to account for the space + // between the previous section, if any, and the start of this section. + if (ctx->memRegion && ctx->memRegion->curPos < dot) + expandMemoryRegion(ctx->memRegion, dot - ctx->memRegion->curPos, + ctx->memRegion->name, sec->name); + switchTo(sec); if (sec->lmaExpr) Index: lld/trunk/test/ELF/linkerscript/memory-gap-explicit-expr.test =================================================================== --- lld/trunk/test/ELF/linkerscript/memory-gap-explicit-expr.test +++ lld/trunk/test/ELF/linkerscript/memory-gap-explicit-expr.test @@ -0,0 +1,18 @@ +# REQUIRES: x86 + +# RUN: echo '.section .aaa, "a"; .quad 0; .section .bbb, "a"; .quad 0;' \ +# RUN: | llvm-mc -filetype=obj -triple=x86_64 - -o %t.o +# RUN: ld.lld %t.o --script %s -o %t +# RUN: llvm-readelf -S %t | FileCheck %s + +# CHECK: .aaa PROGBITS 0000000000000000 001000 000008 +# CHECK: .bbb PROGBITS 0000000000000014 001014 000008 + +MEMORY { + REGION (rwx) : ORIGIN = 0x0000, LENGTH = 0x100 +} + +SECTIONS { + .aaa 0 : { *(.aaa) } > REGION + .bbb 0x14 : { *(.bbb) } > REGION +}