diff options
| author | George Rimar <grimar@accesssoftek.com> | 2016-09-17 18:14:56 +0000 |
|---|---|---|
| committer | George Rimar <grimar@accesssoftek.com> | 2016-09-17 18:14:56 +0000 |
| commit | 8c658bf824d3682041c6e65306c05d091977e787 (patch) | |
| tree | c969891ca5aff63f7f1e2754ede2ed84c5c10219 | |
| parent | 06f85e43cf3068805777ee913da6987c191375f1 (diff) | |
| download | bcm5719-llvm-8c658bf824d3682041c6e65306c05d091977e787.tar.gz bcm5719-llvm-8c658bf824d3682041c6e65306c05d091977e787.zip | |
[ELF] - SEGMENT_START's default argument can be an expression
Our implementation supported integer value previously.
ld can use expression,
for example, it is OK to write
. = SEGMENT_START("foobar", .);
Patch implements that.
llvm-svn: 281831
| -rw-r--r-- | lld/ELF/LinkerScript.cpp | 6 | ||||
| -rw-r--r-- | lld/test/ELF/linkerscript/Inputs/segment-start.script | 2 | ||||
| -rw-r--r-- | lld/test/ELF/linkerscript/segment-start.s | 4 |
3 files changed, 5 insertions, 7 deletions
diff --git a/lld/ELF/LinkerScript.cpp b/lld/ELF/LinkerScript.cpp index d6f406e5c28..597d3bad369 100644 --- a/lld/ELF/LinkerScript.cpp +++ b/lld/ELF/LinkerScript.cpp @@ -1427,11 +1427,9 @@ Expr ScriptParser::readPrimary() { expect("("); next(); expect(","); - uint64_t Val; - if (next().getAsInteger(0, Val)) - setError("integer expected"); + Expr E = readExpr(); expect(")"); - return [=](uint64_t Dot) { return Val; }; + return [=](uint64_t Dot) { return E(Dot); }; } if (Tok == "DATA_SEGMENT_ALIGN") { expect("("); diff --git a/lld/test/ELF/linkerscript/Inputs/segment-start.script b/lld/test/ELF/linkerscript/Inputs/segment-start.script index 95933a290d5..9f1a5936010 100644 --- a/lld/test/ELF/linkerscript/Inputs/segment-start.script +++ b/lld/test/ELF/linkerscript/Inputs/segment-start.script @@ -2,6 +2,6 @@ SECTIONS { PROVIDE (foobar1 = SEGMENT_START("text-segment", 0x8001)); PROVIDE (foobar2 = SEGMENT_START("data-segment", 0x8002)); - PROVIDE (foobar3 = SEGMENT_START("bss-segment", 0x8003)); + PROVIDE (foobar3 = SEGMENT_START("bss-segment", 0x8000 + (4 - 1))); PROVIDE (foobar4 = SEGMENT_START("abc-segment", 0x8004)); } diff --git a/lld/test/ELF/linkerscript/segment-start.s b/lld/test/ELF/linkerscript/segment-start.s index fb00ef13a2c..00245e42e96 100644 --- a/lld/test/ELF/linkerscript/segment-start.s +++ b/lld/test/ELF/linkerscript/segment-start.s @@ -12,7 +12,7 @@ // CHECK: Name: foobar3 // CHECK-NEXT: Value: 0x8003 -// CHECK: Name: foobar +// CHECK: Name: foobar4 // CHECK-NEXT: Value: 0x8004 .data @@ -24,4 +24,4 @@ // RUN: echo "SECTIONS { . = SEGMENT_START(\"foobar\", foo); }" > %t.script // RUN: not ld.lld %t.o %t.script -shared -o %t2.so 2>&1 \ // RUN: | FileCheck --check-prefix=ERR %s -// ERR: integer expected +// ERR: symbol not found: foo |

