summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGeorge Rimar <grimar@accesssoftek.com>2016-09-17 18:14:56 +0000
committerGeorge Rimar <grimar@accesssoftek.com>2016-09-17 18:14:56 +0000
commit8c658bf824d3682041c6e65306c05d091977e787 (patch)
treec969891ca5aff63f7f1e2754ede2ed84c5c10219
parent06f85e43cf3068805777ee913da6987c191375f1 (diff)
downloadbcm5719-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.cpp6
-rw-r--r--lld/test/ELF/linkerscript/Inputs/segment-start.script2
-rw-r--r--lld/test/ELF/linkerscript/segment-start.s4
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
OpenPOWER on IntegriCloud