summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorDuncan Sands <baldrick@free.fr>2008-02-18 17:32:13 +0000
committerDuncan Sands <baldrick@free.fr>2008-02-18 17:32:13 +0000
commit85fab3a3ad55e20171b4081d47e764cd44a99009 (patch)
treefbbd408a5fb824bbe5914ad1b08046afe5362b32 /llvm/lib
parent8ed77c41d874534d6a31a00ff2cd5c60c75afadd (diff)
downloadbcm5719-llvm-85fab3a3ad55e20171b4081d47e764cd44a99009.tar.gz
bcm5719-llvm-85fab3a3ad55e20171b4081d47e764cd44a99009.zip
Simplify caller updating using a CallSite, as
requested by Chris. While there, do the same for an existing function committed by someone called "lattner" :) llvm-svn: 47273
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Transforms/IPO/GlobalOpt.cpp38
-rw-r--r--llvm/lib/VMCore/Instructions.cpp4
2 files changed, 20 insertions, 22 deletions
diff --git a/llvm/lib/Transforms/IPO/GlobalOpt.cpp b/llvm/lib/Transforms/IPO/GlobalOpt.cpp
index fd71dfb8261..ef76a6e42d4 100644
--- a/llvm/lib/Transforms/IPO/GlobalOpt.cpp
+++ b/llvm/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()));
}
}
diff --git a/llvm/lib/VMCore/Instructions.cpp b/llvm/lib/VMCore/Instructions.cpp
index b945a5a0dd7..1a4a5ce7258 100644
--- a/llvm/lib/VMCore/Instructions.cpp
+++ b/llvm/lib/VMCore/Instructions.cpp
@@ -27,6 +27,10 @@ using namespace llvm;
// 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();
OpenPOWER on IntegriCloud