Author: baldrick Date: Mon Feb 18 11:32:13 2008 New Revision: 47273 URL: http://llvm.org/viewvc/llvm-project?rev=47273&view=rev Log: Simplify caller updating using a CallSite, as requested by Chris. While there, do the same for an existing function committed by someone called "lattner" :)
Modified: llvm/trunk/include/llvm/Support/CallSite.h llvm/trunk/lib/Transforms/IPO/GlobalOpt.cpp llvm/trunk/lib/VMCore/Instructions.cpp Modified: llvm/trunk/include/llvm/Support/CallSite.h URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/Support/CallSite.h?rev=47273&r1=47272&r2=47273&view=diff ============================================================================== --- llvm/trunk/include/llvm/Support/CallSite.h (original) +++ llvm/trunk/include/llvm/Support/CallSite.h Mon Feb 18 11:32:13 2008 @@ -35,6 +35,7 @@ CallSite() : I(0) {} CallSite(CallInst *CI) : I(reinterpret_cast<Instruction*>(CI)) {} CallSite(InvokeInst *II) : I(reinterpret_cast<Instruction*>(II)) {} + CallSite(Instruction *C); CallSite(const CallSite &CS) : I(CS.I) {} CallSite &operator=(const CallSite &CS) { I = CS.I; return *this; } Modified: llvm/trunk/lib/Transforms/IPO/GlobalOpt.cpp URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/IPO/GlobalOpt.cpp?rev=47273&r1=47272&r2=47273&view=diff ============================================================================== --- llvm/trunk/lib/Transforms/IPO/GlobalOpt.cpp (original) +++ llvm/trunk/lib/Transforms/IPO/GlobalOpt.cpp Mon Feb 18 11:32:13 2008 @@ -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 @@ /// 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 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())); } } Modified: llvm/trunk/lib/VMCore/Instructions.cpp URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/VMCore/Instructions.cpp?rev=47273&r1=47272&r2=47273&view=diff ============================================================================== --- llvm/trunk/lib/VMCore/Instructions.cpp (original) +++ llvm/trunk/lib/VMCore/Instructions.cpp Mon Feb 18 11:32:13 2008 @@ -27,6 +27,10 @@ // CallSite Class //===----------------------------------------------------------------------===// +CallSite::CallSite(Instruction *C) { + assert((isa<CallInst>(C) || isa<InvokeInst>(C)) && "Not a call!"); + I = C; +} unsigned CallSite::getCallingConv() const { if (CallInst *CI = dyn_cast<CallInst>(I)) return CI->getCallingConv(); _______________________________________________ llvm-commits mailing list llvm-commits@cs.uiuc.edu http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits