From: Eli Friedman Date: Thu, 3 Nov 2011 20:31:28 +0000 (+0000) Subject: Fix the alignment on scalar parameter variables so that it matches what the AST think... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=ddfb8d1026d8f9001d8111bd8a96d89301aa11cd;p=clang Fix the alignment on scalar parameter variables so that it matches what the AST thinks it should be. Per report on cfe-dev. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@143645 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGDecl.cpp b/lib/CodeGen/CGDecl.cpp index a6147ea765..384d92a9bf 100644 --- a/lib/CodeGen/CGDecl.cpp +++ b/lib/CodeGen/CGDecl.cpp @@ -1442,7 +1442,10 @@ void CodeGenFunction::EmitParmDecl(const VarDecl &D, llvm::Value *Arg, DeclPtr = Arg; } else { // Otherwise, create a temporary to hold the value. - DeclPtr = CreateMemTemp(Ty, D.getName() + ".addr"); + llvm::AllocaInst *Alloc = CreateTempAlloca(ConvertTypeForMem(Ty), + D.getName() + ".addr"); + Alloc->setAlignment(getContext().getDeclAlign(&D).getQuantity()); + DeclPtr = Alloc; bool doStore = true; diff --git a/test/CodeGen/align-param.c b/test/CodeGen/align-param.c new file mode 100644 index 0000000000..15a8c2a79a --- /dev/null +++ b/test/CodeGen/align-param.c @@ -0,0 +1,9 @@ +// RUN: %clang_cc1 -emit-llvm -triple i386-apple-macosx10.7.2 < %s | FileCheck %s + +// The preferred alignment for a long long on x86-32 is 8; make sure the +// alloca for x uses that alignment. +int test (long long x) { + return (int)x; +} +// CHECK: define i32 @test +// CHECK: alloca i64, align 8