Propagate calling convention information to function declarations and CallInst
instructions. llvm-svn: 48077
This commit is contained in:
parent
1d4000ba50
commit
aca747a34a
|
|
@ -595,9 +595,11 @@ RValue CodeGenFunction::EmitCallExpr(llvm::Value *Callee, QualType FnType,
|
|||
}
|
||||
}
|
||||
|
||||
llvm::Value *V = Builder.CreateCall(Callee, &Args[0], &Args[0]+Args.size());
|
||||
if (V->getType() != llvm::Type::VoidTy)
|
||||
V->setName("call");
|
||||
llvm::CallInst *CI = Builder.CreateCall(Callee,&Args[0],&Args[0]+Args.size());
|
||||
if (const llvm::Function *F = dyn_cast<llvm::Function>(Callee))
|
||||
CI->setCallingConv(F->getCallingConv());
|
||||
if (CI->getType() != llvm::Type::VoidTy)
|
||||
CI->setName("call");
|
||||
else if (ResultType->isComplexType())
|
||||
return RValue::getComplex(LoadComplexFromAddr(Args[0], false));
|
||||
else if (hasAggregateLLVMType(ResultType))
|
||||
|
|
@ -606,8 +608,8 @@ RValue CodeGenFunction::EmitCallExpr(llvm::Value *Callee, QualType FnType,
|
|||
else {
|
||||
// void return.
|
||||
assert(ResultType->isVoidType() && "Should only have a void expr here");
|
||||
V = 0;
|
||||
CI = 0;
|
||||
}
|
||||
|
||||
return RValue::get(V);
|
||||
return RValue::get(CI);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -18,6 +18,7 @@
|
|||
#include "clang/Basic/Diagnostic.h"
|
||||
#include "clang/Basic/LangOptions.h"
|
||||
#include "clang/Basic/TargetInfo.h"
|
||||
#include "llvm/CallingConv.h"
|
||||
#include "llvm/Constants.h"
|
||||
#include "llvm/DerivedTypes.h"
|
||||
#include "llvm/Module.h"
|
||||
|
|
@ -87,8 +88,13 @@ llvm::Constant *CodeGenModule::GetAddrOfFunctionDecl(const FunctionDecl *D,
|
|||
// If it doesn't already exist, just create and return an entry.
|
||||
if (F == 0) {
|
||||
// FIXME: param attributes for sext/zext etc.
|
||||
return Entry = new llvm::Function(FTy, llvm::Function::ExternalLinkage,
|
||||
D->getName(), &getModule());
|
||||
F = new llvm::Function(FTy, llvm::Function::ExternalLinkage, D->getName(),
|
||||
&getModule());
|
||||
|
||||
// Set the appropriate calling convention for the Function.
|
||||
if (D->getAttr<FastCallAttr>())
|
||||
F->setCallingConv(llvm::CallingConv::Fast);
|
||||
return Entry = F;
|
||||
}
|
||||
|
||||
// If the pointer type matches, just return it.
|
||||
|
|
|
|||
Loading…
Reference in New Issue