[PATCH] D29332: [ELF] - Linkerscript: properly mark minus expression with non-absolute flag
George Rimar via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Feb 1 01:12:36 PST 2017
This revision was automatically updated to reflect the committed changes.
Closed by commit rL293748: [ELF] - Linkerscript: properly mark minus expression with non-absolute flag (authored by grimar).
Changed prior to commit:
https://reviews.llvm.org/D29332?vs=86439&id=86588#toc
Repository:
rL LLVM
https://reviews.llvm.org/D29332
Files:
lld/trunk/ELF/LinkerScript.cpp
lld/trunk/test/ELF/linkerscript/non-absolute.s
Index: lld/trunk/ELF/LinkerScript.cpp
===================================================================
--- lld/trunk/ELF/LinkerScript.cpp
+++ lld/trunk/ELF/LinkerScript.cpp
@@ -1612,6 +1612,12 @@
Expr ScriptParser::readExpr() { return readExpr1(readPrimary(), 0); }
static Expr combine(StringRef Op, Expr L, Expr R) {
+ auto IsAbs = [=] { return L.IsAbsolute() && R.IsAbsolute(); };
+ auto GetOutSec = [=] {
+ const OutputSectionBase *S = L.Section();
+ return S ? S : R.Section();
+ };
+
if (Op == "*")
return [=](uint64_t Dot) { return L(Dot) * R(Dot); };
if (Op == "/") {
@@ -1625,14 +1631,9 @@
};
}
if (Op == "+")
- return {[=](uint64_t Dot) { return L(Dot) + R(Dot); },
- [=] { return L.IsAbsolute() && R.IsAbsolute(); },
- [=] {
- const OutputSectionBase *S = L.Section();
- return S ? S : R.Section();
- }};
+ return {[=](uint64_t Dot) { return L(Dot) + R(Dot); }, IsAbs, GetOutSec};
if (Op == "-")
- return [=](uint64_t Dot) { return L(Dot) - R(Dot); };
+ return {[=](uint64_t Dot) { return L(Dot) - R(Dot); }, IsAbs, GetOutSec};
if (Op == "<<")
return [=](uint64_t Dot) { return L(Dot) << R(Dot); };
if (Op == ">>")
Index: lld/trunk/test/ELF/linkerscript/non-absolute.s
===================================================================
--- lld/trunk/test/ELF/linkerscript/non-absolute.s
+++ lld/trunk/test/ELF/linkerscript/non-absolute.s
@@ -0,0 +1,30 @@
+# REQUIRES: x86
+# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t1.o
+# RUN: echo "SECTIONS { A = . - 0x10; B = A + 0x1; }" > %t.script
+# RUN: ld.lld -shared %t1.o --script %t.script -o %t
+# RUN: llvm-objdump -d %t | FileCheck %s --check-prefix=DUMP
+# RUN: llvm-readobj -t %t | FileCheck %s --check-prefix=SYMBOL
+
+# DUMP: Disassembly of section .text:
+# DUMP-NEXT: foo:
+# DUMP-NEXT: 0: {{.*}} -21(%rip), %eax
+
+# SYMBOL: Symbol {
+# SYMBOL: Name: B
+# SYMBOL-NEXT: Value: 0xFFFFFFFFFFFFFFF1
+# SYMBOL-NEXT: Size: 0
+# SYMBOL-NEXT: Binding: Local
+# SYMBOL-NEXT: Type: None
+# SYMBOL-NEXT: Other [
+# SYMBOL-NEXT: STV_HIDDEN
+# SYMBOL-NEXT: ]
+# SYMBOL-NEXT: Section: .text
+# SYMBOL-NEXT: }
+
+.text
+.globl foo
+.type foo, @function
+foo:
+ movl B(%rip), %eax
+
+.hidden B
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D29332.86588.patch
Type: text/x-patch
Size: 2323 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20170201/cba73975/attachment.bin>
More information about the llvm-commits
mailing list