Index: ELF/LinkerScript.h =================================================================== --- ELF/LinkerScript.h +++ ELF/LinkerScript.h @@ -84,6 +84,7 @@ Expr AddrExpr; Expr AlignExpr; Expr LmaExpr; + Expr SubalignExpr; std::vector> Commands; std::vector Phdrs; std::vector Filler; Index: ELF/LinkerScript.cpp =================================================================== --- ELF/LinkerScript.cpp +++ ELF/LinkerScript.cpp @@ -283,8 +283,12 @@ std::tie(OutSec, IsNew) = Factory.create(Head, Cmd->Name); if (IsNew) OutputSections->push_back(OutSec); - for (InputSectionBase *Sec : V) + + for (InputSectionBase *Sec : V) { + if (Cmd->SubalignExpr) + Sec->Alignment = Cmd->SubalignExpr(0); OutSec->addSection(Sec); + } } } @@ -623,6 +627,7 @@ SymbolAssignment *readProvideOrAssignment(StringRef Tok); Expr readAt(); Expr readAlign(); + Expr readSubAlign(); void readSort(); Expr readAssert(); @@ -907,6 +912,13 @@ return E; } +Expr ScriptParser::readSubAlign() { + expect("("); + Expr E = readExpr(); + expect(")"); + return E; +} + void ScriptParser::readSort() { expect("("); expect("CONSTRUCTORS"); @@ -950,6 +962,8 @@ if (skip("ALIGN")) Cmd->AlignExpr = readAlign(); + if (skip("SUBALIGN")) + Cmd->SubalignExpr = readSubAlign(); // Parse constraints. if (skip("ONLY_IF_RO")) Index: test/ELF/linkerscript/linkerscript-subalign.s =================================================================== --- test/ELF/linkerscript/linkerscript-subalign.s +++ test/ELF/linkerscript/linkerscript-subalign.s @@ -0,0 +1,43 @@ +# REQUIRES: x86 +# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t1.o + +# RUN: echo "SECTIONS { .aaa : { *(.aaa.*) } }" > %t1.script +# RUN: ld.lld -o %t1 --script %t1.script %t1.o +# RUN: llvm-objdump -s %t1 | FileCheck -check-prefix=NOALIGN %s +# NOALIGN: Contents of section .aaa: +# NOALIGN-NEXT: 01000000 00000000 00000000 00000000 +# NOALIGN-NEXT: 00000000 00000000 00000000 00000000 +# NOALIGN-NEXT: 02000000 00000000 00000000 00000000 +# NOALIGN-NEXT: 00000000 00000000 00000000 00000000 +# NOALIGN-NEXT: 03000000 00000000 00000000 00000000 +# NOALIGN-NEXT: 00000000 00000000 00000000 00000000 +# NOALIGN-NEXT: 00000000 00000000 00000000 00000000 +# NOALIGN-NEXT: 00000000 00000000 00000000 00000000 +# NOALIGN-NEXT: 04000000 00000000 + +# RUN: echo "SECTIONS { .aaa : SUBALIGN(1) { *(.aaa.*) } }" > %t2.script +# RUN: ld.lld -o %t2 --script %t2.script %t1.o +# RUN: llvm-objdump -s %t2 | FileCheck -check-prefix=SUBALIGN %s +# SUBALIGN: Contents of section .aaa: +# SUBALIGN: 01000000 00000000 02000000 00000000 +# SUBALIGN: 03000000 00000000 04000000 00000000 + +.global _start +_start: + nop + +.section .aaa.1, "a" +.align 16 +.quad 1 + +.section .aaa.2, "a" +.align 32 +.quad 2 + +.section .aaa.3, "a" +.align 64 +.quad 3 + +.section .aaa.4, "a" +.align 128 +.quad 4