[lld] r276260 - [ELF] Support FLAGS attribute in program header definition
Eugene Leviant via llvm-commits
llvm-commits at lists.llvm.org
Thu Jul 21 03:43:25 PDT 2016
Author: evgeny777
Date: Thu Jul 21 05:43:25 2016
New Revision: 276260
URL: http://llvm.org/viewvc/llvm-project?rev=276260&view=rev
Log:
[ELF] Support FLAGS attribute in program header definition
Added:
lld/trunk/test/ELF/linkerscript-phdrs-flags.s
Modified:
lld/trunk/ELF/LinkerScript.cpp
lld/trunk/ELF/LinkerScript.h
Modified: lld/trunk/ELF/LinkerScript.cpp
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/LinkerScript.cpp?rev=276260&r1=276259&r2=276260&view=diff
==============================================================================
--- lld/trunk/ELF/LinkerScript.cpp (original)
+++ lld/trunk/ELF/LinkerScript.cpp Thu Jul 21 05:43:25 2016
@@ -334,7 +334,7 @@ LinkerScript<ELFT>::createPhdrs(ArrayRef
std::vector<Phdr> Phdrs;
for (const PhdrsCommand &Cmd : Opt.PhdrsCommands) {
- Phdrs.emplace_back(Cmd.Type, PF_R);
+ Phdrs.emplace_back(Cmd.Type, Cmd.Flags == UINT_MAX ? PF_R : Cmd.Flags);
Phdr &Added = Phdrs.back();
if (Cmd.HasFilehdr)
@@ -387,6 +387,8 @@ LinkerScript<ELFT>::createPhdrs(ArrayRef
// Assign headers specified by linker script
for (size_t Id : PhdrIds) {
Phdrs[Id].add(Sec);
+ if (Opt.PhdrsCommands[Id].Flags == UINT_MAX)
+ Phdrs[Id].H.p_flags |= toPhdrFlags(Sec->getFlags());
Phdrs[Id].H.p_flags |= toPhdrFlags(Sec->getFlags());
}
} else {
@@ -669,7 +671,7 @@ void ScriptParser::readPhdrs() {
expect("{");
while (!Error && !skip("}")) {
StringRef Tok = next();
- Opt.PhdrsCommands.push_back({Tok, PT_NULL, false, false});
+ Opt.PhdrsCommands.push_back({Tok, PT_NULL, false, false, UINT_MAX});
PhdrsCommand &PhdrCmd = Opt.PhdrsCommands.back();
PhdrCmd.Type = readPhdrType();
@@ -681,7 +683,11 @@ void ScriptParser::readPhdrs() {
PhdrCmd.HasFilehdr = true;
else if (Tok == "PHDRS")
PhdrCmd.HasPhdrs = true;
- else
+ else if (Tok == "FLAGS") {
+ expect("(");
+ next().getAsInteger(0, PhdrCmd.Flags);
+ expect(")");
+ } else
setError("unexpected header attribute: " + Tok);
} while (!Error);
}
Modified: lld/trunk/ELF/LinkerScript.h
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/LinkerScript.h?rev=276260&r1=276259&r2=276260&view=diff
==============================================================================
--- lld/trunk/ELF/LinkerScript.h (original)
+++ lld/trunk/ELF/LinkerScript.h Thu Jul 21 05:43:25 2016
@@ -79,6 +79,7 @@ struct PhdrsCommand {
unsigned Type;
bool HasFilehdr;
bool HasPhdrs;
+ unsigned Flags;
};
// ScriptConfiguration holds linker script parse results.
Added: lld/trunk/test/ELF/linkerscript-phdrs-flags.s
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/test/ELF/linkerscript-phdrs-flags.s?rev=276260&view=auto
==============================================================================
--- lld/trunk/test/ELF/linkerscript-phdrs-flags.s (added)
+++ lld/trunk/test/ELF/linkerscript-phdrs-flags.s Thu Jul 21 05:43:25 2016
@@ -0,0 +1,36 @@
+# REQUIRES: x86
+# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t
+# RUN: echo "PHDRS {all PT_LOAD FILEHDR PHDRS FLAGS (7);} \
+# RUN: SECTIONS { \
+# RUN: . = 0x10000200; \
+# RUN: .text : {*(.text.*)} :all \
+# RUN: .foo : {*(.foo.*)} :all \
+# RUN: .data : {*(.data.*)} :all}" > %t.script
+
+# RUN: ld.lld -o %t1 --script %t.script %t
+# RUN: llvm-readobj -program-headers %t1 | FileCheck %s
+# CHECK: ProgramHeaders [
+# CHECK-NEXT: ProgramHeader {
+# CHECK-NEXT: Type: PT_LOAD (0x1)
+# CHECK-NEXT: Offset: 0x0
+# CHECK-NEXT: VirtualAddress: 0x10000000
+# CHECK-NEXT: PhysicalAddress: 0x10000000
+# CHECK-NEXT: FileSize: 521
+# CHECK-NEXT: MemSize: 521
+# CHECK-NEXT: Flags [ (0x7)
+# CHECK-NEXT: PF_R (0x4)
+# CHECK-NEXT: PF_W (0x2)
+# CHECK-NEXT: PF_X (0x1)
+# CHECK-NEXT: ]
+
+.global _start
+_start:
+ nop
+
+.section .foo.1,"a"
+foo1:
+ .long 0
+
+.section .foo.2,"a"
+foo2:
+ .long 0
More information about the llvm-commits
mailing list