forked from OSchip/llvm-project
Add a ReturnValueSlot class. Change the argument order in EmitCall to match the other overload better.
llvm-svn: 92136
This commit is contained in:
parent
363b151ff7
commit
0435ed5875
|
@ -579,9 +579,9 @@ RValue CodeGenFunction::EmitBuiltinExpr(const FunctionDecl *FD,
|
|||
// that function.
|
||||
if (getContext().BuiltinInfo.isLibFunction(BuiltinID) ||
|
||||
getContext().BuiltinInfo.isPredefinedLibFunction(BuiltinID))
|
||||
return EmitCall(CGM.getBuiltinLibFunction(FD, BuiltinID),
|
||||
E->getCallee()->getType(), E->arg_begin(),
|
||||
E->arg_end());
|
||||
return EmitCall(E->getCallee()->getType(),
|
||||
CGM.getBuiltinLibFunction(FD, BuiltinID),
|
||||
E->arg_begin(), E->arg_end());
|
||||
|
||||
// See if we have a target specific intrinsic.
|
||||
const char *Name = getContext().BuiltinInfo.GetName(BuiltinID);
|
||||
|
|
|
@ -88,9 +88,8 @@ RValue CodeGenFunction::EmitCXXMemberCallExpr(const CXXMemberCallExpr *CE) {
|
|||
if (MD->isStatic()) {
|
||||
// The method is static, emit it as we would a regular call.
|
||||
llvm::Value *Callee = CGM.GetAddrOfFunction(MD);
|
||||
return EmitCall(Callee, getContext().getPointerType(MD->getType()),
|
||||
CE->arg_begin(), CE->arg_end(), 0);
|
||||
|
||||
return EmitCall(getContext().getPointerType(MD->getType()), Callee,
|
||||
CE->arg_begin(), CE->arg_end());
|
||||
}
|
||||
|
||||
const FunctionProtoType *FPT = MD->getType()->getAs<FunctionProtoType>();
|
||||
|
|
|
@ -15,7 +15,8 @@
|
|||
#ifndef CLANG_CODEGEN_CGCALL_H
|
||||
#define CLANG_CODEGEN_CGCALL_H
|
||||
|
||||
#include <llvm/ADT/FoldingSet.h>
|
||||
#include "llvm/ADT/FoldingSet.h"
|
||||
#include "llvm/Value.h"
|
||||
#include "clang/AST/Type.h"
|
||||
|
||||
#include "CGValue.h"
|
||||
|
@ -123,6 +124,21 @@ namespace CodeGen {
|
|||
begin->Profile(ID);
|
||||
}
|
||||
};
|
||||
|
||||
class ReturnValueSlot {
|
||||
llvm::PointerIntPair<llvm::Value *, 1, bool> Value;
|
||||
|
||||
public:
|
||||
ReturnValueSlot() {}
|
||||
ReturnValueSlot(llvm::Value *Value, bool IsVolatile)
|
||||
: Value(Value, IsVolatile) {}
|
||||
|
||||
bool isNull() const { return !getValue(); }
|
||||
|
||||
bool isVolatile() const { return Value.getInt(); }
|
||||
llvm::Value *getValue() const { return Value.getPointer(); }
|
||||
};
|
||||
|
||||
} // end namespace CodeGen
|
||||
} // end namespace clang
|
||||
|
||||
|
|
|
@ -1551,7 +1551,7 @@ RValue CodeGenFunction::EmitCallExpr(const CallExpr *E) {
|
|||
}
|
||||
|
||||
llvm::Value *Callee = EmitScalarExpr(E->getCallee());
|
||||
return EmitCall(Callee, E->getCallee()->getType(),
|
||||
return EmitCall(E->getCallee()->getType(), Callee,
|
||||
E->arg_begin(), E->arg_end(), TargetDecl);
|
||||
}
|
||||
|
||||
|
@ -1712,7 +1712,7 @@ LValue CodeGenFunction::EmitPointerToDataMemberLValue(const FieldDecl *Field) {
|
|||
return LValue::MakeAddr(V, MakeQualifiers(Field->getType()));
|
||||
}
|
||||
|
||||
RValue CodeGenFunction::EmitCall(llvm::Value *Callee, QualType CalleeType,
|
||||
RValue CodeGenFunction::EmitCall(QualType CalleeType, llvm::Value *Callee,
|
||||
CallExpr::const_arg_iterator ArgBeg,
|
||||
CallExpr::const_arg_iterator ArgEnd,
|
||||
const Decl *TargetDecl) {
|
||||
|
|
|
@ -1039,7 +1039,7 @@ public:
|
|||
const CallArgList &Args,
|
||||
const Decl *TargetDecl = 0);
|
||||
|
||||
RValue EmitCall(llvm::Value *Callee, QualType FnType,
|
||||
RValue EmitCall(QualType FnType, llvm::Value *Callee,
|
||||
CallExpr::const_arg_iterator ArgBeg,
|
||||
CallExpr::const_arg_iterator ArgEnd,
|
||||
const Decl *TargetDecl = 0);
|
||||
|
|
Loading…
Reference in New Issue