add support for new linkage types

llvm-svn: 9228
diff --git a/llvm/lib/Bytecode/Writer/Writer.cpp b/llvm/lib/Bytecode/Writer/Writer.cpp
index 0968461..5cc3eec 100644
--- a/llvm/lib/Bytecode/Writer/Writer.cpp
+++ b/llvm/lib/Bytecode/Writer/Writer.cpp
@@ -162,10 +162,10 @@
   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 @@
     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);