diff options
author | Tom Stellard <thomas.stellard@amd.com> | 2016-10-28 15:32:28 +0000 |
---|---|---|
committer | Tom Stellard <thomas.stellard@amd.com> | 2016-10-28 15:32:28 +0000 |
commit | 13068995b9c397a6cfcc6243fa47d1e8edad0f21 (patch) | |
tree | 928bca7e7cae3859211f2d1bc31ea6ff01f59502 /llvm/test/Analysis/ValueTracking | |
parent | d01fcc71590c320b4c7d111876c81bd3adc3e230 (diff) | |
download | bcm5719-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.ll | 21 |
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 +} |