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/CodeGen/PowerPC/or-addressing-mode.ll b/test/CodeGen/PowerPC/or-addressing-mode.ll
new file mode 100644
index 0000000..e448140
--- /dev/null
+++ b/test/CodeGen/PowerPC/or-addressing-mode.ll
@@ -0,0 +1,22 @@
+; RUN: llvm-upgrade < %s | llvm-as | llc -mtriple=powerpc-apple-darwin8 | not grep ori
+; RUN: llvm-upgrade < %s | llvm-as | llc -mtriple=powerpc-apple-darwin8 | not grep rlwimi
+
+int %test1(sbyte* %P) {  ;; or -> lwzx
+        %tmp.2.i = cast sbyte* %P to uint
+        %tmp.4.i = and uint %tmp.2.i, 4294901760
+        %tmp.10.i = shr uint %tmp.2.i, ubyte 5
+        %tmp.11.i = and uint %tmp.10.i, 2040
+        %tmp.13.i = or uint %tmp.11.i, %tmp.4.i
+        %tmp.14.i = cast uint %tmp.13.i to int*
+        %tmp.3 = load int* %tmp.14.i
+        ret int %tmp.3
+}
+
+int %test2(int %P) {    ;; or -> lwz
+        %tmp.2 = shl int %P, ubyte 4
+        %tmp.3 = or int %tmp.2, 2
+        %tmp.4 = cast int %tmp.3 to int*
+        %tmp.5 = load int* %tmp.4
+        ret int %tmp.5
+}
+