It's not necessary to do rounding for alloca operations when the requested
alignment is equal to the stack alignment.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@40004 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/test/Transforms/ScalarRepl/2003-10-29-ArrayProblem.ll b/test/Transforms/ScalarRepl/2003-10-29-ArrayProblem.ll
new file mode 100644
index 0000000..d945aeb
--- /dev/null
+++ b/test/Transforms/ScalarRepl/2003-10-29-ArrayProblem.ll
@@ -0,0 +1,15 @@
+; RUN: llvm-upgrade < %s | llvm-as | opt -scalarrepl | llvm-dis | \
+; RUN:   grep alloca | grep \{
+implementation   ; Functions:
+
+declare int %.callback_1(sbyte*)
+declare void %.iter_2(int (sbyte*)*, sbyte*)
+
+int %main() {
+	%d = alloca { [80 x sbyte], int, uint }
+	%tmp.0 = getelementptr { [80 x sbyte], int, uint }* %d, long 0, uint 2
+	store uint 0, uint* %tmp.0
+	%tmp.1 = getelementptr { [80 x sbyte], int, uint }* %d, long 0, uint 0, long 0
+	call void %.iter_2( int (sbyte*)* %.callback_1, sbyte* %tmp.1 )
+	ret int 0
+}