summaryrefslogtreecommitdiffstats
path: root/llvm/test/Analysis/ValueTracking
diff options
context:
space:
mode:
authorTom Stellard <thomas.stellard@amd.com>2016-10-28 15:32:28 +0000
committerTom Stellard <thomas.stellard@amd.com>2016-10-28 15:32:28 +0000
commit13068995b9c397a6cfcc6243fa47d1e8edad0f21 (patch)
tree928bca7e7cae3859211f2d1bc31ea6ff01f59502 /llvm/test/Analysis/ValueTracking
parentd01fcc71590c320b4c7d111876c81bd3adc3e230 (diff)
downloadbcm5719-llvm-13068995b9c397a6cfcc6243fa47d1e8edad0f21.tar.gz
bcm5719-llvm-13068995b9c397a6cfcc6243fa47d1e8edad0f21.zip
[Loads] Fix crash in is isDereferenceableAndAlignedPointer()
Summary: We were trying to add APInt values with different bit sizes after visiting an addrspacecast instruction which changed the bit width of the pointer. Reviewers: majnemer, hfinkel Subscribers: hfinkel, wdng, llvm-commits Differential Revision: https://reviews.llvm.org/D24774 llvm-svn: 285407
Diffstat (limited to 'llvm/test/Analysis/ValueTracking')
-rw-r--r--llvm/test/Analysis/ValueTracking/dereferenceable-and-aligned.ll21
1 files changed, 21 insertions, 0 deletions
diff --git a/llvm/test/Analysis/ValueTracking/dereferenceable-and-aligned.ll b/llvm/test/Analysis/ValueTracking/dereferenceable-and-aligned.ll
new file mode 100644
index 00000000000..8af0548db11
--- /dev/null
+++ b/llvm/test/Analysis/ValueTracking/dereferenceable-and-aligned.ll
@@ -0,0 +1,21 @@
+; RUN: opt < %s -licm -S | FileCheck %s
+
+target datalayout = "e-p:32:32-p1:64:64-p4:64:64"
+
+; Make sure isDereferenceableAndAlignePointer() doesn't crash when looking
+; walking pointer defs with an addrspacecast that changes pointer size.
+; CHECK-LABEL: @addrspacecast_crash
+define void @addrspacecast_crash() {
+bb:
+ %tmp = alloca [256 x i32]
+ br label %bb1
+
+bb1:
+ %tmp2 = getelementptr inbounds [256 x i32], [256 x i32]* %tmp, i32 0, i32 36
+ %tmp3 = bitcast i32* %tmp2 to <4 x i32>*
+ %tmp4 = addrspacecast <4 x i32>* %tmp3 to <4 x i32> addrspace(4)*
+ %tmp5 = load <4 x i32>, <4 x i32> addrspace(4)* %tmp4
+ %tmp6 = xor <4 x i32> %tmp5, undef
+ store <4 x i32> %tmp6, <4 x i32> addrspace(1)* undef
+ br label %bb1
+}
OpenPOWER on IntegriCloud