Skip to content

Commit

Permalink
[ELF] - Linkerscript: implemented ALIGN modificatior of output sections.
Browse files Browse the repository at this point in the history
Output section description can contain ALIGN modificator:
https://sourceware.org/binutils/docs/ld/Output-Section-Description.html#Output-Section-Description

Patch implements it.

Differential revision: https://reviews.llvm.org/D22674

llvm-svn: 276780
  • Loading branch information
George Rimar committed Jul 26, 2016
1 parent cb42ea0 commit 630c617
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 0 deletions.
13 changes: 13 additions & 0 deletions lld/ELF/LinkerScript.cpp
Expand Up @@ -226,6 +226,9 @@ void LinkerScript<ELFT>::assignAddresses(
if (Cmd->AddrExpr)
Dot = Cmd->AddrExpr(Dot);

if (Cmd->AlignExpr)
Sec->updateAlignment(Cmd->AlignExpr(Dot));

if ((Sec->getFlags() & SHF_TLS) && Sec->getType() == SHT_NOBITS) {
uintX_t TVA = Dot + ThreadBssOffset;
TVA = alignTo(TVA, Sec->getAlignment());
Expand Down Expand Up @@ -433,6 +436,7 @@ class elf::ScriptParser : public ScriptParserBase {
std::vector<StringRef> readOutputSectionPhdrs();
unsigned readPhdrType();
void readProvide(bool Hidden);
void readAlign(OutputSectionCommand *Cmd);

Expr readExpr();
Expr readExpr1(Expr Lhs, int MinPrec);
Expand Down Expand Up @@ -671,6 +675,12 @@ void ScriptParser::readKeep(OutputSectionCommand *Cmd) {
expect(")");
}

void ScriptParser::readAlign(OutputSectionCommand *Cmd) {
expect("(");
Cmd->AlignExpr = readExpr();
expect(")");
}

void ScriptParser::readOutputSectionDescription(StringRef OutSec) {
OutputSectionCommand *Cmd = new OutputSectionCommand(OutSec);
Opt.Commands.emplace_back(Cmd);
Expand All @@ -682,6 +692,9 @@ void ScriptParser::readOutputSectionDescription(StringRef OutSec) {

expect(":");

if (skip("ALIGN"))
readAlign(Cmd);

// Parse constraints.
if (skip("ONLY_IF_RO"))
Cmd->Constraint = ConstraintKind::ReadOnly;
Expand Down
1 change: 1 addition & 0 deletions lld/ELF/LinkerScript.h
Expand Up @@ -73,6 +73,7 @@ struct OutputSectionCommand : BaseCommand {
static bool classof(const BaseCommand *C);
StringRef Name;
Expr AddrExpr;
Expr AlignExpr;
std::vector<std::unique_ptr<BaseCommand>> Commands;
std::vector<StringRef> Phdrs;
std::vector<uint8_t> Filler;
Expand Down
20 changes: 20 additions & 0 deletions lld/test/ELF/linkerscript/linkerscript-align.s
@@ -1,6 +1,7 @@
# REQUIRES: x86
# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t

## Check that ALIGN command workable using location counter
# RUN: echo "SECTIONS { \
# RUN: . = 0x10000; \
# RUN: .aaa : \
Expand All @@ -27,6 +28,25 @@
# CHECK-NEXT: 2 .bbb 00000008 0000000000011000 DATA
# CHECK-NEXT: 3 .ccc 00000008 0000000000014000 DATA

## Check output sections ALIGN modificator
# RUN: echo "SECTIONS { \
# RUN: . = 0x10000; \
# RUN: .aaa : \
# RUN: { \
# RUN: *(.aaa) \
# RUN: } \
# RUN: .bbb : ALIGN(4096) \
# RUN: { \
# RUN: *(.bbb) \
# RUN: } \
# RUN: .ccc : ALIGN(4096 * 4) \
# RUN: { \
# RUN: *(.ccc) \
# RUN: } \
# RUN: }" > %t2.script
# RUN: ld.lld -o %t2 --script %t2.script %t
# RUN: llvm-objdump -section-headers %t1 | FileCheck %s

.global _start
_start:
nop
Expand Down

0 comments on commit 630c617

Please sign in to comment.