David Majnemer 3b7e6d27d2 ValueTracking: Don't recurse too deeply in computeKnownBitsFromAssume
Respect the MaxDepth recursion limit, doing otherwise will trigger an
assert in computeKnownBits.

This fixes PR21891.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@224168 91177308-0d34-0410-b5e6-96231b3b80d8
2014-12-12 23:59:29 +00:00

19 lines
485 B
LLVM

; RUN: opt %s -instcombine
define i32 @f(i32 %theNumber) {
entry:
%cmp = icmp sgt i32 %theNumber, -1
call void @llvm.assume(i1 %cmp)
br i1 true, label %if.then, label %if.end
if.then: ; preds = %entry
%shl = shl nuw i32 %theNumber, 1
br label %if.end
if.end: ; preds = %if.then, %entry
%phi = phi i32 [ %shl, %if.then ], [ undef, %entry ]
ret i32 %phi
}
declare void @llvm.assume(i1)