add support for new linkage types
authorChris Lattner <sabre@nondot.org>
Sat, 18 Oct 2003 06:30:21 +0000 (06:30 +0000)
committerChris Lattner <sabre@nondot.org>
Sat, 18 Oct 2003 06:30:21 +0000 (06:30 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@9228 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Bytecode/Reader/Reader.cpp
lib/Bytecode/Writer/Writer.cpp

index 1674786fb76f6b94481093d688d64babc8eba23e..e338c41e5267b5dde6e1b811f3cbb3010f8c24f6 100644 (file)
@@ -434,14 +434,24 @@ void BytecodeParser::ParseModuleGlobalInfo(const unsigned char *&Buf,
     GlobalValue::LinkageTypes Linkage;
 
     if (!hasInternalMarkerOnly) {
-      // VarType Fields: bit0 = isConstant, bit1 = hasInitializer,
-      // bit2,3 = Linkage, bit4+ = slot#
-      SlotNo = VarType >> 4;
-      switch ((VarType >> 2) & 3) {
+      unsigned LinkageID;
+      if (hasExtendedLinkageSpecs) {
+        // VarType Fields: bit0 = isConstant, bit1 = hasInitializer,
+        // bit2,3,4 = Linkage, bit4+ = slot#
+        SlotNo = VarType >> 5;
+        LinkageID = (VarType >> 2) & 7;
+      } else {
+        // VarType Fields: bit0 = isConstant, bit1 = hasInitializer,
+        // bit2,3 = Linkage, bit4+ = slot#
+        SlotNo = VarType >> 4;
+        LinkageID = (VarType >> 2) & 3;
+      }
+      switch (LinkageID) {
       case 0: Linkage = GlobalValue::ExternalLinkage;  break;
       case 1: Linkage = GlobalValue::WeakLinkage;      break;
       case 2: Linkage = GlobalValue::AppendingLinkage; break;
       case 3: Linkage = GlobalValue::InternalLinkage;  break;
+      case 4: Linkage = GlobalValue::LinkOnceLinkage;  break;
       }
     } else {
       // VarType Fields: bit0 = isConstant, bit1 = hasInitializer,
index 096846145673a1814a3105e27db6989d8ff2624a..5cc3eec8722c838dad62bfc663a1ba0188672742 100644 (file)
@@ -162,10 +162,10 @@ static unsigned getEncodedLinkage(const GlobalValue *GV) {
   switch (GV->getLinkage()) {
   default: assert(0 && "Invalid linkage!");
   case GlobalValue::ExternalLinkage:  return 0;
-  case GlobalValue::LinkOnceLinkage:  return 1;
   case GlobalValue::WeakLinkage:      return 1;
   case GlobalValue::AppendingLinkage: return 2;
   case GlobalValue::InternalLinkage:  return 3;
+  case GlobalValue::LinkOnceLinkage:  return 4;
   }
 }
 
@@ -177,9 +177,9 @@ void BytecodeWriter::outputModuleInfoBlock(const Module *M) {
     int Slot = Table.getSlot(I->getType());
     assert(Slot != -1 && "Module global vars is broken!");
 
-    // Fields: bit0 = isConstant, bit1 = hasInitializer, bit2,3=Linkage,
-    // bit4+ = Slot # for type
-    unsigned oSlot = ((unsigned)Slot << 4) | (getEncodedLinkage(I) << 2) |
+    // Fields: bit0 = isConstant, bit1 = hasInitializer, bit2-4=Linkage,
+    // bit5+ = Slot # for type
+    unsigned oSlot = ((unsigned)Slot << 5) | (getEncodedLinkage(I) << 2) |
                      (I->hasInitializer() << 1) | I->isConstant();
     output_vbr(oSlot, Out);