MCStreamer: Add a few more "symbol attributes".
authorDaniel Dunbar <daniel@zuster.org>
Wed, 24 Jun 2009 16:36:52 +0000 (16:36 +0000)
committerDaniel Dunbar <daniel@zuster.org>
Wed, 24 Jun 2009 16:36:52 +0000 (16:36 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@74077 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/MC/MCStreamer.h
lib/MC/MCAsmStreamer.cpp

index 9374529ff43d642afbe92b26598ec2e59fdfac4a..76374160e8046d75de6c1097e84874b27eeb6714 100644 (file)
@@ -23,9 +23,21 @@ namespace llvm {
   class MCStreamer {
   public:
     enum SymbolAttr {
-      Global,
-      Weak,
-      PrivateExtern
+      Global,         /// .globl
+      Hidden,         /// .hidden (ELF)
+      IndirectSymbol, /// .indirect_symbol (Apple)
+      Internal,       /// .internal (ELF)
+      LazyReference,  /// .lazy_reference (Apple)
+      NoDeadStrip,    /// .no_dead_strip (Apple)
+      PrivateExtern,  /// .private_extern (Apple)
+      Protected,      /// .protected (ELF)
+      Reference,      /// .reference (Apple)
+      Weak,           /// .weak
+      WeakDefinition, /// .weak_definition (Apple)
+      WeakReference,  /// .weak_reference (Apple)
+
+      SymbolAttrFirst = Global,
+      SymbolAttrLast = WeakReference
     };
 
   private:
index efc9e65fe2c54a634d21fabc6b10401a8ab7e62e..33d72e29f918624f52209b5be4444e9a9f7ed0ac 100644 (file)
@@ -102,8 +102,17 @@ void MCAsmStreamer::EmitSymbolAttribute(MCSymbol *Symbol,
                                         SymbolAttr Attribute) {
   switch (Attribute) {
   case Global: OS << ".globl"; break;
-  case Weak: OS << ".weak"; break;
+  case Hidden: OS << ".hidden"; break;
+  case IndirectSymbol: OS << ".indirect_symbol"; break;
+  case Internal: OS << ".internal"; break;
+  case LazyReference: OS << ".lazy_reference"; break;
+  case NoDeadStrip: OS << ".no_dead_strip"; break;
   case PrivateExtern: OS << ".private_extern"; break;
+  case Protected: OS << ".protected"; break;
+  case Reference: OS << ".reference"; break;
+  case Weak: OS << ".weak"; break;
+  case WeakDefinition: OS << ".weak_definition"; break;
+  case WeakReference: OS << ".weak_reference"; break;
   }
 
   OS << ' ' << Symbol->getName() << '\n';