teach ipsccp and ipconstprop that a blockaddress doesn't 'take the address' of a...
authorChris Lattner <sabre@nondot.org>
Sun, 1 Nov 2009 06:11:53 +0000 (06:11 +0000)
committerChris Lattner <sabre@nondot.org>
Sun, 1 Nov 2009 06:11:53 +0000 (06:11 +0000)
in a way that should prevent ip constprop.  This allows clang/test/CodeGen/indirect-goto.c
to pass with the new indirect goto lowering.

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

lib/Transforms/IPO/IPConstantPropagation.cpp
lib/Transforms/Scalar/SCCP.cpp

index d9b2e3063143be1eb3ca501741dcf1fb726e6760..023e642e648c716236f88c6d6fe258b442b6240b 100644 (file)
@@ -86,6 +86,9 @@ bool IPCP::PropagateConstantsIntoArguments(Function &F) {
 
   unsigned NumNonconstant = 0;
   for (Value::use_iterator UI = F.use_begin(), E = F.use_end(); UI != E; ++UI) {
+    // Ignore blockaddress uses.
+    if (isa<BlockAddress>(*UI)) continue;
+    
     // Used by a non-instruction, or not the callee of a function, do not
     // transform.
     if (!isa<CallInst>(*UI) && !isa<InvokeInst>(*UI))
index 4e5fae8a0414bbaf96966f937e5f97e628c0bfcd..a348e20907e2b56ae571a7a2cde868c546724637 100644 (file)
@@ -1680,12 +1680,14 @@ static bool AddressIsTaken(GlobalValue *GV) {
         return true;  // Storing addr of GV.
     } else if (isa<InvokeInst>(*UI) || isa<CallInst>(*UI)) {
       // Make sure we are calling the function, not passing the address.
-      CallSite CS = CallSite::get(cast<Instruction>(*UI));
-      if (CS.hasArgument(GV))
+      if (UI.getOperandNo() != 0)
         return true;
     } else if (LoadInst *LI = dyn_cast<LoadInst>(*UI)) {
       if (LI->isVolatile())
         return true;
+    } else if (isa<BlockAddress>(*UI)) {
+      // blockaddress doesn't take the address of the function, it takes addr
+      // of label.
     } else {
       return true;
     }