diff options
author | Duncan Sands <baldrick@free.fr> | 2008-02-18 17:32:13 +0000 |
---|---|---|
committer | Duncan Sands <baldrick@free.fr> | 2008-02-18 17:32:13 +0000 |
commit | 548448a317b39ec8446f3c82f44d01f938b921b2 (patch) | |
tree | 6a9bf3ec62a59f98f241a07abb4379996c0adebc /lib/Transforms/IPO | |
parent | bb494bcb0e3b25297412d609eec774edccab7575 (diff) | |
download | external_llvm-548448a317b39ec8446f3c82f44d01f938b921b2.zip external_llvm-548448a317b39ec8446f3c82f44d01f938b921b2.tar.gz external_llvm-548448a317b39ec8446f3c82f44d01f938b921b2.tar.bz2 |
Simplify caller updating using a CallSite, as
requested by Chris. While there, do the same
for an existing function committed by someone
called "lattner" :)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@47273 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/IPO')
-rw-r--r-- | lib/Transforms/IPO/GlobalOpt.cpp | 38 |
1 files changed, 16 insertions, 22 deletions
diff --git a/lib/Transforms/IPO/GlobalOpt.cpp b/lib/Transforms/IPO/GlobalOpt.cpp index fd71dfb..ef76a6e 100644 --- a/lib/Transforms/IPO/GlobalOpt.cpp +++ b/lib/Transforms/IPO/GlobalOpt.cpp @@ -25,6 +25,7 @@ #include "llvm/Pass.h" #include "llvm/Analysis/ConstantFolding.h" #include "llvm/Target/TargetData.h" +#include "llvm/Support/CallSite.h" #include "llvm/Support/Compiler.h" #include "llvm/Support/Debug.h" #include "llvm/Support/GetElementPtrTypeIterator.h" @@ -1584,25 +1585,23 @@ static bool OnlyCalledDirectly(Function *F) { /// function, changing them to FastCC. static void ChangeCalleesToFastCall(Function *F) { for (Value::use_iterator UI = F->use_begin(), E = F->use_end(); UI != E;++UI){ - Instruction *User = cast<Instruction>(*UI); - if (CallInst *CI = dyn_cast<CallInst>(User)) - CI->setCallingConv(CallingConv::Fast); - else - cast<InvokeInst>(User)->setCallingConv(CallingConv::Fast); + CallSite User(cast<Instruction>(*UI)); + User.setCallingConv(CallingConv::Fast); } } static const ParamAttrsList *StripNest(const ParamAttrsList *Attrs) { - if (Attrs) { - for (unsigned i = 0, e = Attrs->size(); i != e; ++i) { - uint16_t A = Attrs->getParamAttrsAtIndex(i); - if (A & ParamAttr::Nest) { - Attrs = ParamAttrsList::excludeAttrs(Attrs, Attrs->getParamIndex(i), - ParamAttr::Nest); - // There can be only one. - break; - } - } + if (!Attrs) + return NULL; + + for (unsigned i = 0, e = Attrs->size(); i != e; ++i) { + if ((Attrs->getParamAttrsAtIndex(i) & ParamAttr::Nest) == 0) + continue; + + Attrs = ParamAttrsList::excludeAttrs(Attrs, Attrs->getParamIndex(i), + ParamAttr::Nest); + // There can be only one. + break; } return Attrs; @@ -1611,13 +1610,8 @@ static const ParamAttrsList *StripNest(const ParamAttrsList *Attrs) { static void RemoveNestAttribute(Function *F) { F->setParamAttrs(StripNest(F->getParamAttrs())); for (Value::use_iterator UI = F->use_begin(), E = F->use_end(); UI != E;++UI){ - Instruction *User = cast<Instruction>(*UI); - if (CallInst *CI = dyn_cast<CallInst>(User)) { - CI->setParamAttrs(StripNest(CI->getParamAttrs())); - } else { - InvokeInst *II = cast<InvokeInst>(User); - II->setParamAttrs(StripNest(II->getParamAttrs())); - } + CallSite User(cast<Instruction>(*UI)); + User.setParamAttrs(StripNest(User.getParamAttrs())); } } |