diff options
author | Chris Lattner <sabre@nondot.org> | 2007-06-20 04:44:43 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2007-06-20 04:44:43 +0000 |
commit | b6984c485428a1e9564eb63296c1f8009ac8de00 (patch) | |
tree | 9cc06e9c138d1829657d2a5f9f9e8892aaf36d57 /clang/CodeGen/CodeGenFunction.cpp | |
parent | b3fef07a3077da3af60598245c388beb152636f8 (diff) | |
download | bcm5719-llvm-b6984c485428a1e9564eb63296c1f8009ac8de00.tar.gz bcm5719-llvm-b6984c485428a1e9564eb63296c1f8009ac8de00.zip |
Hook up global function and variable handling. We can now compile:
int X, bar(int,int,int);
short Y;
double foo() {
return bar(X, Y, 3);
}
into:
@X = external global i32 ; <i32*> [#uses=1]
@Y = external global i16 ; <i16*> [#uses=1]
define double @foo() {
entry:
%tmp = load i32* @X ; <i32> [#uses=1]
%tmp1 = load i16* @Y ; <i16> [#uses=1]
%promote = sext i16 %tmp1 to i32 ; <i32> [#uses=1]
%call = tail call i32 @bar( i32 %tmp, i32 %promote, i32 3 ) ; <i32> [#uses=1]
%conv = sitofp i32 %call to double ; <double> [#uses=1]
ret double %conv
}
declare i32 @bar(i32, i32, i32)
llvm-svn: 39663
Diffstat (limited to 'clang/CodeGen/CodeGenFunction.cpp')
-rw-r--r-- | clang/CodeGen/CodeGenFunction.cpp | 15 |
1 files changed, 6 insertions, 9 deletions
diff --git a/clang/CodeGen/CodeGenFunction.cpp b/clang/CodeGen/CodeGenFunction.cpp index d3abbc97e2b..3c4a68baeac 100644 --- a/clang/CodeGen/CodeGenFunction.cpp +++ b/clang/CodeGen/CodeGenFunction.cpp @@ -47,14 +47,11 @@ void CodeGenFunction::GenerateCode(const FunctionDecl *FD) { LLVMIntTy = ConvertType(getContext().IntTy, FD->getLocation()); LLVMPointerWidth = Target.getPointerWidth(FD->getLocation()); - const llvm::FunctionType *Ty = - cast<llvm::FunctionType>(ConvertType(FD->getType(), FD->getLocation())); - - // FIXME: param attributes for sext/zext etc. - + CurFn = cast<llvm::Function>(CGM.GetAddrOfGlobalDecl(FD)); CurFuncDecl = FD; - CurFn = new llvm::Function(Ty, llvm::Function::ExternalLinkage, - FD->getName(), &CGM.getModule()); + + // TODO: Set up linkage and many other things. + assert(CurFn->isDeclaration() && "Function already has body?"); llvm::BasicBlock *EntryBB = new llvm::BasicBlock("entry", CurFn); @@ -77,10 +74,10 @@ void CodeGenFunction::GenerateCode(const FunctionDecl *FD) { // Emit a return for code that falls off the end. // FIXME: if this is C++ main, this should return 0. - if (Ty->getReturnType() == llvm::Type::VoidTy) + if (CurFn->getReturnType() == llvm::Type::VoidTy) Builder.CreateRetVoid(); else - Builder.CreateRet(llvm::UndefValue::get(Ty->getReturnType())); + Builder.CreateRet(llvm::UndefValue::get(CurFn->getReturnType())); // Verify that the function is well formed. assert(!verifyFunction(*CurFn)); |