summaryrefslogtreecommitdiffstats
path: root/clang/CodeGen/CodeGenFunction.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2007-06-20 04:44:43 +0000
committerChris Lattner <sabre@nondot.org>2007-06-20 04:44:43 +0000
commitb6984c485428a1e9564eb63296c1f8009ac8de00 (patch)
tree9cc06e9c138d1829657d2a5f9f9e8892aaf36d57 /clang/CodeGen/CodeGenFunction.cpp
parentb3fef07a3077da3af60598245c388beb152636f8 (diff)
downloadbcm5719-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.cpp15
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));
OpenPOWER on IntegriCloud