aboutsummaryrefslogtreecommitdiff
path: root/lib/Transforms/IPO/ArgumentPromotion.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-03-07 22:43:27 +0000
committerChris Lattner <sabre@nondot.org>2004-03-07 22:43:27 +0000
commit7db5a6df78749bf0cd37870fcefe08b8849e38e6 (patch)
tree52daa47569c1e6228cdcc5c8a58a696869e3e87c /lib/Transforms/IPO/ArgumentPromotion.cpp
parentc76d80342e229a86bf3f780c797e29d197363bc4 (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.cpp14
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.