New testcase for memmove -> memcpy transform
authorChris Lattner <sabre@nondot.org>
Tue, 12 Oct 2004 04:51:55 +0000 (04:51 +0000)
committerChris Lattner <sabre@nondot.org>
Tue, 12 Oct 2004 04:51:55 +0000 (04:51 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@16931 91177308-0d34-0410-b5e6-96231b3b80d8

test/Transforms/InstCombine/memmove.ll [new file with mode: 0644]

diff --git a/test/Transforms/InstCombine/memmove.ll b/test/Transforms/InstCombine/memmove.ll
new file mode 100644 (file)
index 0000000..1313d34
--- /dev/null
@@ -0,0 +1,23 @@
+; This test makes sure that memmove instructions are properly eliminated.
+;
+
+; RUN: llvm-as < %s | opt -instcombine | llvm-dis | not grep 'call void %llvm.memmove'
+
+%S = internal constant [33 x sbyte] c"panic: restorelist inconsistency\00"
+
+implementation
+
+declare void %llvm.memmove(sbyte*, sbyte*, uint, uint)
+
+void %test1(sbyte* %A, sbyte* %B, uint %N) {
+       ;; 0 bytes -> noop.
+       call void %llvm.memmove(sbyte* %A, sbyte* %B, uint 0, uint 1)
+       ret void
+}
+
+void %test2(sbyte *%A, uint %N) {
+       ;; dest can't alias source since we can't write to source!
+       call void %llvm.memmove(sbyte* %A, sbyte* getelementptr ([33 x sbyte]* %S, int 0, int 0), 
+                                uint %N, uint 1)
+       ret void
+}