mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-10 22:46:20 +00:00
af1480aea6
isKnownNonEqual(A, B) returns true if it can be determined that A != B. At the moment it only knows two facts, that a non-wrapping add of nonzero to a value cannot be that value: A + B != A [where B != 0, addition is nsw or nuw] and that contradictory known bits imply two values are not equal. This patch also hooks this up to InstSimplify; InstSimplify had a peephole for the first fact but not the second so this teaches InstSimplify a new trick too (alas no measured performance impact!) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@251012 91177308-0d34-0410-b5e6-96231b3b80d8
22 lines
526 B
LLVM
22 lines
526 B
LLVM
; RUN: opt -instsimplify < %s -S | FileCheck %s
|
|
|
|
; CHECK: define i1 @test
|
|
define i1 @test(i8* %pq, i8 %B) {
|
|
%q = load i8, i8* %pq, !range !0 ; %q is known nonzero; no known bits
|
|
%A = add nsw i8 %B, %q
|
|
%cmp = icmp eq i8 %A, %B
|
|
; CHECK: ret i1 false
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK: define i1 @test2
|
|
define i1 @test2(i8 %a, i8 %b) {
|
|
%A = or i8 %a, 2 ; %A[1] = 1
|
|
%B = and i8 %b, -3 ; %B[1] = 0
|
|
%cmp = icmp eq i8 %A, %B ; %A[1] and %B[1] are contradictory.
|
|
; CHECK: ret i1 false
|
|
ret i1 %cmp
|
|
}
|
|
|
|
!0 = !{ i8 1, i8 5 }
|