finally give Mangler a getSymbol method, which returns an MCSymbol
authorChris Lattner <sabre@nondot.org>
Fri, 12 Mar 2010 18:55:20 +0000 (18:55 +0000)
committerChris Lattner <sabre@nondot.org>
Fri, 12 Mar 2010 18:55:20 +0000 (18:55 +0000)
for a global instead of messing around with string buffers.

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

include/llvm/Target/Mangler.h
lib/CodeGen/AsmPrinter/AsmPrinter.cpp
lib/Target/Mangler.cpp
lib/Target/TargetLoweringObjectFile.cpp

index d3845021d9e4b66adb56717a384ac1ce95b3821d..2b7d192e1e2fa27eda803cc8f0e8a7d6491ea229 100644 (file)
@@ -1,4 +1,4 @@
-//===-- llvm/Target/Mangler.h - Self-contained name mangler ----*- C++ -*-===//
+//===-- llvm/Target/Mangler.h - Self-contained name mangler -----*- C++ -*-===//
 //
 //                     The LLVM Compiler Infrastructure
 //
@@ -24,6 +24,7 @@ class Value;
 class GlobalValue;
 template <typename T> class SmallVectorImpl; 
 class MCContext;
+class MCSymbol;
 
 class Mangler {
 public:
@@ -34,7 +35,7 @@ public:
   };
 
 private:
-  const MCContext &Context;
+  MCContext &Context;
 
   /// AnonGlobalIDs - We need to give global values the same name every time
   /// they are mangled.  This keeps track of the number we give to anonymous
@@ -47,8 +48,13 @@ private:
   unsigned NextAnonGlobalID;
 
 public:
-  Mangler(const MCContext &context) : Context(context), NextAnonGlobalID(1) {}
+  Mangler(MCContext &context) : Context(context), NextAnonGlobalID(1) {}
 
+  /// getSymbol - Return the MCSymbol for the specified global value.  This
+  /// symbol is the main label that is the address of the global.
+  MCSymbol *getSymbol(const GlobalValue *GV);
+
+  
   /// getNameWithPrefix - Fill OutName with the name of the appropriate prefix
   /// and the specified global variable's name.  If the global variable doesn't
   /// have a name, this fills in a unique name for the global.
index c5bf848edcb1e609c2507b3b628db062b0a644a9..0a283931edaf35e5981e59a8b12b06ae5f3f3f12 100644 (file)
@@ -1632,12 +1632,7 @@ MCSymbol *AsmPrinter::GetJTSetSymbol(unsigned UID, unsigned MBBID) const {
 /// GetGlobalValueSymbol - Return the MCSymbol for the specified global
 /// value.
 MCSymbol *AsmPrinter::GetGlobalValueSymbol(const GlobalValue *GV) const {
-  SmallString<60> NameStr;
-  Mang->getNameWithPrefix(NameStr, GV, false);
-  
-  if (!GV->hasPrivateLinkage())
-    return OutContext.GetOrCreateSymbol(NameStr.str());
-  return OutContext.GetOrCreateTemporarySymbol(NameStr.str());
+  return Mang->getSymbol(GV);
 }
 
 /// GetSymbolWithGlobalValueBase - Return the MCSymbol for a symbol with
index 3eab58cc36d28779baf66e286d46e6fad3384fd3..c630062bdfac03a4a64db719e7ab2e2cc6185d3f 100644 (file)
@@ -179,3 +179,16 @@ std::string Mangler::getNameWithPrefix(const GlobalValue *GV,
   getNameWithPrefix(Buf, GV, isImplicitlyPrivate);
   return std::string(Buf.begin(), Buf.end());
 }
+
+/// getSymbol - Return the MCSymbol for the specified global value.  This
+/// symbol is the main label that is the address of the global.
+MCSymbol *Mangler::getSymbol(const GlobalValue *GV) {
+  SmallString<60> NameStr;
+  getNameWithPrefix(NameStr, GV, false);
+  if (!GV->hasPrivateLinkage())
+    return Context.GetOrCreateSymbol(NameStr.str());
+  
+  return Context.GetOrCreateTemporarySymbol(NameStr.str());
+}
+
+
index 5a960d8085255ef51c86ec0f0603d341b3b2d80e..a093e2db8b2e7b1f589d7ea2c504b334964e0815 100644 (file)
@@ -298,16 +298,7 @@ const MCExpr *TargetLoweringObjectFile::
 getExprForDwarfGlobalReference(const GlobalValue *GV, Mangler *Mang,
                                MachineModuleInfo *MMI, unsigned Encoding,
                                MCStreamer &Streamer) const {
-  // FIXME: Use GetGlobalValueSymbol.
-  SmallString<128> Name;
-  Mang->getNameWithPrefix(Name, GV, false);
-  const MCSymbol *Sym;
-  
-  if (GV->hasPrivateLinkage())
-    Sym = getContext().GetOrCreateTemporarySymbol(Name.str());
-  else
-    Sym = getContext().GetOrCreateSymbol(Name.str());
-
+  const MCSymbol *Sym = Mang->getSymbol(GV);
   return getExprForDwarfReference(Sym, Mang, MMI, Encoding, Streamer);
 }