summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms
diff options
context:
space:
mode:
authorBob Wilson <bob.wilson@apple.com>2010-01-19 04:32:48 +0000
committerBob Wilson <bob.wilson@apple.com>2010-01-19 04:32:48 +0000
commit58d59fe394e7c773bff27b412d90f5d0523187aa (patch)
tree154f772cf26e4391ece10c37b2d3d8459cfe9ef1 /llvm/test/Transforms
parent35474ca4c49c98ca51247fde8ead6f82187090cd (diff)
downloadbcm5719-llvm-58d59fe394e7c773bff27b412d90f5d0523187aa.tar.gz
bcm5719-llvm-58d59fe394e7c773bff27b412d90f5d0523187aa.zip
Fix a crash in scalarrepl for memcpy/memmove where the source and destination
are the same. I had already fixed a similar problem where the source and destination were different bitcasts derived from the same alloca, but the previous fix still did not handle the case where both operands are exactly the same value. Radar 7552893. llvm-svn: 93848
Diffstat (limited to 'llvm/test/Transforms')
-rw-r--r--llvm/test/Transforms/ScalarRepl/2010-01-18-SelfCopy.ll18
1 files changed, 18 insertions, 0 deletions
diff --git a/llvm/test/Transforms/ScalarRepl/2010-01-18-SelfCopy.ll b/llvm/test/Transforms/ScalarRepl/2010-01-18-SelfCopy.ll
new file mode 100644
index 00000000000..74cf251503c
--- /dev/null
+++ b/llvm/test/Transforms/ScalarRepl/2010-01-18-SelfCopy.ll
@@ -0,0 +1,18 @@
+; RUN: opt < %s -scalarrepl -S | FileCheck %s
+; Radar 7552893
+
+target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128-n8:16:32"
+
+%struct.test = type { [3 x double ] }
+
+define arm_apcscc void @test_memcpy_self() nounwind {
+; CHECK: @test_memcpy_self
+; CHECK-NOT: alloca
+; CHECK: ret void
+ %1 = alloca %struct.test
+ %2 = bitcast %struct.test* %1 to i8*
+ call void @llvm.memcpy.i32(i8* %2, i8* %2, i32 24, i32 4)
+ ret void
+}
+
+declare void @llvm.memcpy.i32(i8* nocapture, i8* nocapture, i32, i32) nounwind
OpenPOWER on IntegriCloud