Fix PR6673: updating the callback should not clear the map.
authorChris Lattner <sabre@nondot.org>
Mon, 22 Mar 2010 23:15:57 +0000 (23:15 +0000)
committerChris Lattner <sabre@nondot.org>
Mon, 22 Mar 2010 23:15:57 +0000 (23:15 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@99227 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/MachineModuleInfo.cpp
test/CodeGen/Generic/addr-label.ll

index af48e9ebb5b33be39412b616d97d7012eb64aeb6..ad4f01b7a9ad87eb193427faf28281d0f6b454b8 100644 (file)
@@ -44,6 +44,10 @@ public:
   MMIAddrLabelMapCallbackPtr() : Map(0) {}
   MMIAddrLabelMapCallbackPtr(Value *V) : CallbackVH(V), Map(0) {}
   
+  void setPtr(BasicBlock *BB) {
+    ValueHandleBase::operator=(BB);
+  }
+    
   void setMap(MMIAddrLabelMap *map) { Map = map; }
   
   virtual void deleted();
@@ -209,7 +213,7 @@ void MMIAddrLabelMap::UpdateForRAUWBlock(BasicBlock *Old, BasicBlock *New) {
 
   // If New is not address taken, just move our symbol over to it.
   if (NewEntry.Symbols.isNull()) {
-    BBCallbacks[OldEntry.Index] = New;    // Update the callback.
+    BBCallbacks[OldEntry.Index].setPtr(New);    // Update the callback.
     NewEntry = OldEntry;     // Set New's entry.
     return;
   }
index 51741110e072edb35bd258d2c2ece0026f3bc7f7..0dbe5021bbf085dd45a59d7d837e4cec097d8b16 100644 (file)
@@ -56,3 +56,26 @@ ret:
        ret i32 -1
 }
 
+
+; PR6673
+
+define i64 @test4a() {
+       %target = bitcast i8* blockaddress(@test4b, %usermain) to i8*
+       %ret = call i64 @test4b(i8* %target)
+
+       ret i64 %ret
+}
+
+define i64 @test4b(i8* %Code) {
+entry:
+       indirectbr i8* %Code, [label %usermain]
+usermain:
+       br label %label_line_0
+
+label_line_0:
+       br label %label_line_1
+
+label_line_1:
+       %target = ptrtoint i8* blockaddress(@test4b, %label_line_0) to i64
+       ret i64 %target
+}