[llvm] r285407 - [Loads] Fix crash in is isDereferenceableAndAlignedPointer()
Tom Stellard via llvm-commits
llvm-commits at lists.llvm.org
Fri Oct 28 08:32:28 PDT 2016
Author: tstellar
Date: Fri Oct 28 10:32:28 2016
New Revision: 285407
URL: http://llvm.org/viewvc/llvm-project?rev=285407&view=rev
Log:
[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
Added:
llvm/trunk/test/Analysis/ValueTracking/dereferenceable-and-aligned.ll
Modified:
llvm/trunk/lib/Analysis/Loads.cpp
Modified: llvm/trunk/lib/Analysis/Loads.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Analysis/Loads.cpp?rev=285407&r1=285406&r2=285407&view=diff
==============================================================================
--- llvm/trunk/lib/Analysis/Loads.cpp (original)
+++ llvm/trunk/lib/Analysis/Loads.cpp Fri Oct 28 10:32:28 2016
@@ -91,8 +91,11 @@ static bool isDereferenceableAndAlignedP
// then the GEP (== Base + Offset == k_0 * Align + k_1 * Align) is also
// aligned to Align bytes.
- return isDereferenceableAndAlignedPointer(Base, Align, Offset + Size, DL,
- CtxI, DT, Visited);
+ // Offset and Size may have different bit widths if we have visited an
+ // addrspacecast, so we can't do arithmetic directly on the APInt values.
+ return isDereferenceableAndAlignedPointer(
+ Base, Align, Offset + Size.sextOrTrunc(Offset.getBitWidth()),
+ DL, CtxI, DT, Visited);
}
// For gc.relocate, look through relocations
Added: llvm/trunk/test/Analysis/ValueTracking/dereferenceable-and-aligned.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Analysis/ValueTracking/dereferenceable-and-aligned.ll?rev=285407&view=auto
==============================================================================
--- llvm/trunk/test/Analysis/ValueTracking/dereferenceable-and-aligned.ll (added)
+++ llvm/trunk/test/Analysis/ValueTracking/dereferenceable-and-aligned.ll Fri Oct 28 10:32:28 2016
@@ -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
+}
More information about the llvm-commits
mailing list