Implement TLSLDM.
authorRafael Espindola <rafael.espindola@gmail.com>
Thu, 28 Oct 2010 14:37:09 +0000 (14:37 +0000)
committerRafael Espindola <rafael.espindola@gmail.com>
Thu, 28 Oct 2010 14:37:09 +0000 (14:37 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@117544 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/MC/MCExpr.h
lib/MC/ELFObjectWriter.cpp
lib/MC/MCExpr.cpp
test/MC/ELF/relocation-386.s

index 4fe1b37aea86b5dab366c664a94b14e60c7833a5..e1f27f156cb34f567a7ddff4b533a64a51f35820 100644 (file)
@@ -137,6 +137,7 @@ public:
     VK_GOTNTPOFF,
     VK_PLT,
     VK_TLSGD,
+    VK_TLSLDM,
     VK_TPOFF,
     VK_ARM_HI16, // The R_ARM_MOVT_ABS relocation (:upper16: in the asm file)
     VK_ARM_LO16, // The R_ARM_MOVW_ABS_NC relocation (:lower16: in the asm file)
index fda8ac47c36ba51c85e7b2b672183d1a4db790e1..22005022851a2b3fab9e9f80dfbeb8d55afca69e 100644 (file)
@@ -91,6 +91,7 @@ static bool RelocNeedsGOT(MCSymbolRefExpr::VariantKind Variant) {
   case MCSymbolRefExpr::VK_INDNTPOFF:
   case MCSymbolRefExpr::VK_NTPOFF:
   case MCSymbolRefExpr::VK_GOTNTPOFF:
+  case MCSymbolRefExpr::VK_TLSLDM:
     return true;
   }
 }
@@ -784,6 +785,9 @@ void ELFObjectWriterImpl::RecordRelocation(const MCAssembler &Asm,
         case MCSymbolRefExpr::VK_GOTNTPOFF:
           Type = ELF::R_386_TLS_GOTIE;
           break;
+        case MCSymbolRefExpr::VK_TLSLDM:
+          Type = ELF::R_386_TLS_LDM;
+          break;
         }
         break;
       case FK_Data_2: Type = ELF::R_386_16; break;
index 39ac1ac7722d1b3be7151a2f8fe168e1e7d43aeb..6ee2520e69a8a763e4be27c13a95d668110b3c81 100644 (file)
@@ -178,6 +178,7 @@ StringRef MCSymbolRefExpr::getVariantKindName(VariantKind Kind) {
   case VK_GOTNTPOFF: return "GOTNTPOFF";
   case VK_PLT: return "PLT";
   case VK_TLSGD: return "TLSGD";
+  case VK_TLSLDM: return "TLSLDM";
   case VK_TPOFF: return "TPOFF";
   case VK_ARM_HI16: return ":upper16:";
   case VK_ARM_LO16: return ":lower16:";
@@ -198,6 +199,7 @@ MCSymbolRefExpr::getVariantKindForName(StringRef Name) {
     .Case("GOTNTPOFF", VK_GOTNTPOFF)
     .Case("PLT", VK_PLT)
     .Case("TLSGD", VK_TLSGD)
+    .Case("TLSLDM", VK_TLSLDM)
     .Case("TPOFF", VK_TPOFF)
     .Case("TLVP", VK_TLVP)
     .Default(VK_Invalid);
index 8a1ff6e5c54780aed6a452d132fc539ca93e0d65..9fb0befb03f858ad4bf01aae4d1d52da7470dff1 100644 (file)
 // CHECK-NEXT:  ('r_type', 0x00000010)
 // CHECK-NEXT: ),
 
+// Relocation 10 (foo@TLSLDM) is of type R_386_TLS_LDM
+// CHECK-NEXT: # Relocation 0x0000000a
+// CHECK-NEXT: (('r_offset', 0x0000003d)
+// CHECK-NEXT:  ('r_sym', 0x0000000b)
+// CHECK-NEXT:  ('r_type', 0x00000013)
+// CHECK-NEXT: ),
         .text
 bar:
        leal    .Lfoo@GOTOFF(%ebx), %eax
@@ -106,6 +112,7 @@ bar2:
         movl foo@INDNTPOFF, %ecx
         addl foo@NTPOFF(%eax), %eax
         addl foo@GOTNTPOFF(%ebx), %ecx
+        leal foo@TLSLDM(%ebx), %eax
 
         .section       .rodata.str1.16,"aMS",@progbits,1
 .Lfoo: