From: Chris Lattner Date: Sun, 1 Nov 2009 06:11:53 +0000 (+0000) Subject: teach ipsccp and ipconstprop that a blockaddress doesn't 'take the address' of a... X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=b2710041fbed34ae888a6fed4172aea92bced1b5;p=oota-llvm.git teach ipsccp and ipconstprop that a blockaddress doesn't 'take the address' of a function 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 --- diff --git a/lib/Transforms/IPO/IPConstantPropagation.cpp b/lib/Transforms/IPO/IPConstantPropagation.cpp index d9b2e306314..023e642e648 100644 --- a/lib/Transforms/IPO/IPConstantPropagation.cpp +++ b/lib/Transforms/IPO/IPConstantPropagation.cpp @@ -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(*UI)) continue; + // Used by a non-instruction, or not the callee of a function, do not // transform. if (!isa(*UI) && !isa(*UI)) diff --git a/lib/Transforms/Scalar/SCCP.cpp b/lib/Transforms/Scalar/SCCP.cpp index 4e5fae8a041..a348e20907e 100644 --- a/lib/Transforms/Scalar/SCCP.cpp +++ b/lib/Transforms/Scalar/SCCP.cpp @@ -1680,12 +1680,14 @@ static bool AddressIsTaken(GlobalValue *GV) { return true; // Storing addr of GV. } else if (isa(*UI) || isa(*UI)) { // Make sure we are calling the function, not passing the address. - CallSite CS = CallSite::get(cast(*UI)); - if (CS.hasArgument(GV)) + if (UI.getOperandNo() != 0) return true; } else if (LoadInst *LI = dyn_cast(*UI)) { if (LI->isVolatile()) return true; + } else if (isa(*UI)) { + // blockaddress doesn't take the address of the function, it takes addr + // of label. } else { return true; }