]> granicus.if.org Git - clang/commitdiff
Make sure EmitMoveFromReturnSlot is passing the correct alignment to
authorChad Rosier <mcrosier@apple.com>
Tue, 17 Apr 2012 00:35:38 +0000 (00:35 +0000)
committerChad Rosier <mcrosier@apple.com>
Tue, 17 Apr 2012 00:35:38 +0000 (00:35 +0000)
EmitFinalDestCopy (and thus pass EmitAggregateCopy the correct alignment).
rdar://11220251

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@154883 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGExprAgg.cpp
test/CodeGen/packed-nest-unpacked.c

index 2103026a84f29a4b7ba4e45f43dc1676faabe8c5..d345154f01311b0f4d569e2205a9842a6e1d3a59 100644 (file)
@@ -238,7 +238,7 @@ void AggExprEmitter::EmitMoveFromReturnSlot(const Expr *E, RValue Src) {
 
   // Otherwise, do a final copy, 
   assert(Dest.getAddr() != Src.getAggregateAddr());
-  EmitFinalDestCopy(E, Src, /*Ignore*/ true);
+  EmitFinalDestCopy(E, Src, /*Ignore*/ true, Dest.getAlignment().getQuantity());
 }
 
 /// EmitFinalDestCopy - Perform the final copy to DestPtr, if desired.
index 3751473331310f300be4cfb5eaff6d16d9f821b4..d10a88a5e34725118ade5cfddc7033abdb907782 100644 (file)
@@ -4,6 +4,7 @@ struct X { int x[6]; };
 struct Y { char x[13]; struct X y; } __attribute((packed));
 struct Y g;
 void f(struct X);
+struct X foo(void);
 
 // <rdar://problem/10463337>
 struct X test1() {
@@ -37,3 +38,10 @@ int test5() {
   // CHECK: load i32* getelementptr inbounds (%struct.Y* @g, i32 0, i32 1, i32 0, i64 0), align 1
   return g.y.x[0];
 }
+
+// <rdar://problem/11220251>
+void test6() {
+  // CHECK: @test6
+  // CHECK: call void @llvm.memcpy.p0i8.p0i8.i64(i8* bitcast (%struct.X* getelementptr inbounds (%struct.Y* @g, i32 0, i32 1) to i8*), i8* %0, i64 24, i32 1, i1 false)
+  g.y = foo();
+}