diff options
author | Chris Lattner <sabre@nondot.org> | 2004-03-07 22:43:27 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2004-03-07 22:43:27 +0000 |
commit | 7db5a6df78749bf0cd37870fcefe08b8849e38e6 (patch) | |
tree | 52daa47569c1e6228cdcc5c8a58a696869e3e87c /lib/Transforms/IPO/ArgumentPromotion.cpp | |
parent | c76d80342e229a86bf3f780c797e29d197363bc4 (diff) |
Fix another minor bug, exposed by perlbmk
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12198 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/IPO/ArgumentPromotion.cpp')
-rw-r--r-- | lib/Transforms/IPO/ArgumentPromotion.cpp | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/lib/Transforms/IPO/ArgumentPromotion.cpp b/lib/Transforms/IPO/ArgumentPromotion.cpp index 639c518037..eb4fc463e6 100644 --- a/lib/Transforms/IPO/ArgumentPromotion.cpp +++ b/lib/Transforms/IPO/ArgumentPromotion.cpp @@ -136,10 +136,18 @@ bool ArgPromotion::PromoteArguments(Function *F) { // Second check: make sure that all callers are direct callers. We can't // transform functions that have indirect callers. for (Value::use_iterator UI = F->use_begin(), E = F->use_end(); - UI != E; ++UI) - // What about CPRs? - if (!CallSite::get(*UI).getInstruction()) + UI != E; ++UI) { + CallSite CS = CallSite::get(*UI); + if (Instruction *I = CS.getInstruction()) { + // Ensure that this call site is CALLING the function, not passing it as + // an argument. + for (CallSite::arg_iterator AI = CS.arg_begin(), E = CS.arg_end(); + AI != E; ++AI) + if (*AI == F) return false; // Passing the function address in! + } else { return false; // Cannot promote an indirect call! + } + } // Check to see which arguments are promotable. If an argument is not // promotable, remove it from the PointerArgs vector. |