[llvm] r201530 - Add support for assigning to . in AsmParser.

Anders Waldenborg anders at 0x63.nu
Mon Feb 17 12:48:32 PST 2014


Author: andersg
Date: Mon Feb 17 14:48:32 2014
New Revision: 201530

URL: http://llvm.org/viewvc/llvm-project?rev=201530&view=rev
Log:
Add support for assigning to . in AsmParser.

This is implemented by handling assignments to the '.' pseudo symbol
as ".org" directives.

Differential Revision: http://llvm-reviews.chandlerc.com/D2625


Added:
    llvm/trunk/test/MC/AsmParser/dot-symbol-assignment-backwards.s
    llvm/trunk/test/MC/AsmParser/dot-symbol-assignment.s
    llvm/trunk/test/MC/AsmParser/dot-symbol-non-absolute.s
    llvm/trunk/test/MC/ELF/dot-symbol-assignment.s
Modified:
    llvm/trunk/lib/MC/MCParser/AsmParser.cpp
    llvm/trunk/test/MC/AsmParser/dot-symbol.s

Modified: llvm/trunk/lib/MC/MCParser/AsmParser.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/MC/MCParser/AsmParser.cpp?rev=201530&r1=201529&r2=201530&view=diff
==============================================================================
--- llvm/trunk/lib/MC/MCParser/AsmParser.cpp (original)
+++ llvm/trunk/lib/MC/MCParser/AsmParser.cpp Mon Feb 17 14:48:32 2014
@@ -2119,12 +2119,6 @@ bool AsmParser::parseAssignment(StringRe
   if (Lexer.isNot(AsmToken::EndOfStatement))
     return TokError("unexpected token in assignment");
 
-  // Error on assignment to '.'.
-  if (Name == ".") {
-    return Error(EqualLoc, ("assignment to pseudo-symbol '.' is unsupported "
-                            "(use '.space' or '.org').)"));
-  }
-
   // Eat the end of statement marker.
   Lex();
 
@@ -2152,11 +2146,15 @@ bool AsmParser::parseAssignment(StringRe
 
     // Don't count these checks as uses.
     Sym->setUsed(false);
+  } else if (Name == ".") {
+    if (Out.EmitValueToOffset(Value, 0)) {
+      Error(EqualLoc, "expected absolute expression");
+      eatToEndOfStatement();
+    }
+    return false;
   } else
     Sym = getContext().GetOrCreateSymbol(Name);
 
-  // FIXME: Handle '.'.
-
   // Do the assignment.
   Out.EmitAssignment(Sym, Value);
   if (NoDeadStrip)

Added: llvm/trunk/test/MC/AsmParser/dot-symbol-assignment-backwards.s
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/AsmParser/dot-symbol-assignment-backwards.s?rev=201530&view=auto
==============================================================================
--- llvm/trunk/test/MC/AsmParser/dot-symbol-assignment-backwards.s (added)
+++ llvm/trunk/test/MC/AsmParser/dot-symbol-assignment-backwards.s Mon Feb 17 14:48:32 2014
@@ -0,0 +1,12 @@
+# RUN: not llvm-mc -filetype=obj -triple i386-unknown-unknown %s 2> %t
+# RUN: FileCheck -input-file %t %s
+
+. = 0x10
+	.byte 1
+
+. = . + 10
+	.byte 2
+
+# CHECK: LLVM ERROR: invalid .org offset '24' (at offset '28')
+. = 0x18
+	.byte 3

Added: llvm/trunk/test/MC/AsmParser/dot-symbol-assignment.s
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/AsmParser/dot-symbol-assignment.s?rev=201530&view=auto
==============================================================================
--- llvm/trunk/test/MC/AsmParser/dot-symbol-assignment.s (added)
+++ llvm/trunk/test/MC/AsmParser/dot-symbol-assignment.s Mon Feb 17 14:48:32 2014
@@ -0,0 +1,31 @@
+# RUN: llvm-mc -triple i386-unknown-unknown %s | FileCheck %s
+
+	.extern	start
+
+# CHECK: .org 1024, 0
+. = 0x400
+	lgdt	0x400 + 0x100
+
+	ljmpl	$0x08, $(0x400 + 0x150)
+
+
+# CHECK: .org 1280, 0
+. = 0x400 + 0x100
+	.word	(3*8)-1
+	.quad	(0x400 + 0x110)
+
+# CHECK: .org 1296, 0
+. = 0x400 + 0x110
+	.quad	0x0
+	.quad	0x0020980000000000
+	.quad	0x0000900000000000
+
+	.code64
+
+# CHECK: .org 1360, 0
+. = 0x400 + 0x150
+	movabsq	$start, %rcx
+	jmp	*%rcx
+
+
+. = 0x300

Added: llvm/trunk/test/MC/AsmParser/dot-symbol-non-absolute.s
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/AsmParser/dot-symbol-non-absolute.s?rev=201530&view=auto
==============================================================================
--- llvm/trunk/test/MC/AsmParser/dot-symbol-non-absolute.s (added)
+++ llvm/trunk/test/MC/AsmParser/dot-symbol-non-absolute.s Mon Feb 17 14:48:32 2014
@@ -0,0 +1,9 @@
+# RUN: not llvm-mc -filetype=obj -triple i386-unknown-unknown %s 2> %t
+# RUN: FileCheck -input-file %t %s
+
+
+	.extern foo
+
+# CHECK: error: expected absolute expression
+. = foo + 10
+	.byte 1

Modified: llvm/trunk/test/MC/AsmParser/dot-symbol.s
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/AsmParser/dot-symbol.s?rev=201530&r1=201529&r2=201530&view=diff
==============================================================================
--- llvm/trunk/test/MC/AsmParser/dot-symbol.s (original)
+++ llvm/trunk/test/MC/AsmParser/dot-symbol.s Mon Feb 17 14:48:32 2014
@@ -1,12 +1,9 @@
 # Historically 'as' treats '.' as a reference to the current location in
-# arbitrary contects. We don't support this in general.
+# arbitrary contexts. We don't support this in general.
 
 # RUN: not llvm-mc -triple i386-unknown-unknown %s 2> %t
 # RUN: FileCheck -input-file %t %s
 
-# CHECK: assignment to pseudo-symbol '.' is unsupported (use '.space' or '.org').
-. = . + 8
-
 # CHECK: invalid use of pseudo-symbol '.' as a label
 .:
         .long 0

Added: llvm/trunk/test/MC/ELF/dot-symbol-assignment.s
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/ELF/dot-symbol-assignment.s?rev=201530&view=auto
==============================================================================
--- llvm/trunk/test/MC/ELF/dot-symbol-assignment.s (added)
+++ llvm/trunk/test/MC/ELF/dot-symbol-assignment.s Mon Feb 17 14:48:32 2014
@@ -0,0 +1,22 @@
+// RUN: llvm-mc -filetype=obj -triple x86_64-pc-linux-gnu %s -o - | llvm-readobj -sections -section-data | FileCheck %s
+
+one:
+	.quad 0xffffffffffffffff
+
+. = . + 16
+two:
+	.quad 0xeeeeeeeeeeeeeeee
+
+. = 0x20
+three:
+	.quad 0xdddddddddddddddd
+
+// CHECK:        Section {
+// CHECK:          Name: .text
+// CHECK-NEXT:     Type:
+// CHECK-NEXT:     Flags [
+// CHECK:          SectionData (
+// CHECK-NEXT:     0000: FFFFFFFF FFFFFFFF 00000000 00000000
+// CHECK-NEXT:     0010: 00000000 00000000 EEEEEEEE EEEEEEEE
+// CHECK-NEXT:     0020: DDDDDDDD DDDDDDDD
+// CHECK-NEXT:     )





More information about the llvm-commits mailing list