Skip to content

Commit

Permalink
[Loads] Fix crash in is isDereferenceableAndAlignedPointer()
Browse files Browse the repository at this point in the history
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
  • Loading branch information
tstellarAMD committed Oct 28, 2016
1 parent d01fcc7 commit 1306899
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 2 deletions.
7 changes: 5 additions & 2 deletions llvm/lib/Analysis/Loads.cpp
Expand Up @@ -91,8 +91,11 @@ static bool isDereferenceableAndAlignedPointer(
// 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
Expand Down
21 changes: 21 additions & 0 deletions 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
}

0 comments on commit 1306899

Please sign in to comment.