[PATCH] D43883: Add "%" operator to the linker script.

Rui Ueyama via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Wed Feb 28 10:31:16 PST 2018


ruiu created this revision.
ruiu added a reviewer: rafael.
Herald added subscribers: arichardson, emaste.

This patch improves compatibility with GNU linkers.


https://reviews.llvm.org/D43883

Files:
  lld/ELF/ScriptParser.cpp
  lld/test/ELF/linkerscript/operators.s


Index: lld/test/ELF/linkerscript/operators.s
===================================================================
--- lld/test/ELF/linkerscript/operators.s
+++ lld/test/ELF/linkerscript/operators.s
@@ -5,6 +5,7 @@
 # RUN:  plus = 1 + 2 + 3; \
 # RUN:  minus = 5 - 1; \
 # RUN:  div = 6 / 2; \
+# RUN:  mod = 20 % 7; \
 # RUN:  mul = 1 + 2 * 3; \
 # RUN:  nospace = 1+2*6/3; \
 # RUN:  braces = 1 + (2 + 3) * 4; \
@@ -37,6 +38,7 @@
 # CHECK: 00000000000006 *ABS* 00000000 plus
 # CHECK: 00000000000004 *ABS* 00000000 minus
 # CHECK: 00000000000003 *ABS* 00000000 div
+# CHECK: 00000000000006 *ABS* 00000000 mod
 # CHECK: 00000000000007 *ABS* 00000000 mul
 # CHECK: 00000000000005 *ABS* 00000000 nospace
 # CHECK: 00000000000015 *ABS* 00000000 braces
Index: lld/ELF/ScriptParser.cpp
===================================================================
--- lld/ELF/ScriptParser.cpp
+++ lld/ELF/ScriptParser.cpp
@@ -168,6 +168,13 @@
   return 0;
 }
 
+static ExprValue mod(ExprValue A, ExprValue B) {
+  if (uint64_t BV = B.getValue())
+    return A.getValue() % BV;
+  error("modulo by zero");
+  return 0;
+}
+
 static ExprValue bitAnd(ExprValue A, ExprValue B) {
   moveAbsRight(A, B);
   return {A.Sec, A.ForceAbsolute,
@@ -461,7 +468,7 @@
 
 static int precedence(StringRef Op) {
   return StringSwitch<int>(Op)
-      .Cases("*", "/", 5)
+      .Cases("*", "/", "%", 5)
       .Cases("+", "-", 4)
       .Cases("<<", ">>", 3)
       .Cases("<", "<=", ">", ">=", "==", "!=", 2)
@@ -811,6 +818,8 @@
     return [=] { return mul(L(), R()); };
   if (Op == "/")
     return [=] { return div(L(), R()); };
+  if (Op == "%")
+    return [=] { return mod(L(), R()); };
   if (Op == "<<")
     return [=] { return L().getValue() << R().getValue(); };
   if (Op == ">>")


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D43883.136334.patch
Type: text/x-patch
Size: 1762 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20180228/0ba1dfcc/attachment.bin>


More information about the llvm-commits mailing list