]> granicus.if.org Git - clang/commitdiff
Fix the alignment on scalar parameter variables so that it matches what the AST think...
authorEli Friedman <eli.friedman@gmail.com>
Thu, 3 Nov 2011 20:31:28 +0000 (20:31 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Thu, 3 Nov 2011 20:31:28 +0000 (20:31 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@143645 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGDecl.cpp
test/CodeGen/align-param.c [new file with mode: 0644]

index a6147ea7658bfa624b5beab2cd56fa1d3369bc26..384d92a9bf4239d95779e95908122ef325683ec2 100644 (file)
@@ -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 (file)
index 0000000..15a8c2a
--- /dev/null
@@ -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