Do not recurse into symbol refs that have a variant kind. This prevents us
authorRafael Espindola <rafael.espindola@gmail.com>
Thu, 21 Oct 2010 18:00:20 +0000 (18:00 +0000)
committerRafael Espindola <rafael.espindola@gmail.com>
Thu, 21 Oct 2010 18:00:20 +0000 (18:00 +0000)
from losing the variant when producing a relocation on an alias.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@117037 91177308-0d34-0410-b5e6-96231b3b80d8

lib/MC/MCExpr.cpp
test/MC/ELF/alias-reloc.s [new file with mode: 0644]

index 3524b8035c0aa88e1b64977a95ead566322af521..abc3b51c79c08eb19fb406e5a1639d9a1d4c2a40 100644 (file)
@@ -306,7 +306,7 @@ bool MCExpr::EvaluateAsRelocatableImpl(MCValue &Res,
     const MCSymbol &Sym = SRE->getSymbol();
 
     // Evaluate recursively if this is a variable.
-    if (Sym.isVariable())
+    if (Sym.isVariable() && SRE->getKind() == MCSymbolRefExpr::VK_None)
       return Sym.getVariableValue()->EvaluateAsRelocatableImpl(Res, Layout,
                                                                true);
 
diff --git a/test/MC/ELF/alias-reloc.s b/test/MC/ELF/alias-reloc.s
new file mode 100644 (file)
index 0000000..e31afa1
--- /dev/null
@@ -0,0 +1,16 @@
+// RUN: llvm-mc -filetype=obj -triple x86_64-pc-linux-gnu %s -o - | elf-dump  | FileCheck %s
+
+// Test that this produces a R_X86_64_PLT32. We produce a relocation with foo
+// and gas with bar, but both should be OK as long as the type is correct.
+        .globl foo
+foo:
+bar = foo
+        call bar@PLT
+
+// CHECK:       # Relocation 0
+// CHECK-NEXT:  (('r_offset',
+// CHECK-NEXT:   ('r_sym',
+// CHECK-NEXT:   ('r_type', 0x00000004)
+// CHECK-NEXT:   ('r_addend',
+// CHECK-NEXT:  ),
+// CHECK-NEXT: ])