mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-28 06:32:09 +00:00
Use the right kind of booleans: we were emitting 0/1 booleans, instead of 0/-1
booleans. Patch by James Benton. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@159739 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4a002ab9c3
commit
e7de3b29f7
@ -2390,21 +2390,29 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
|
||||
}
|
||||
|
||||
if (N0 == N1) {
|
||||
// We can always fold X == X for integer setcc's.
|
||||
if (N0.getValueType().isInteger()) {
|
||||
// The sext(setcc()) => setcc() optimization relies on the appropriate
|
||||
// constant being emitted.
|
||||
uint64_t EqVal;
|
||||
switch (getBooleanContents(N0.getValueType().isVector())) {
|
||||
default: llvm_unreachable("Unknown boolean contents!");
|
||||
case UndefinedBooleanContent:
|
||||
case ZeroOrOneBooleanContent:
|
||||
return DAG.getConstant(ISD::isTrueWhenEqual(Cond), VT);
|
||||
EqVal = ISD::isTrueWhenEqual(Cond);
|
||||
break;
|
||||
case ZeroOrNegativeOneBooleanContent:
|
||||
return DAG.getConstant(ISD::isTrueWhenEqual(Cond) ? -1 : 0, VT);
|
||||
EqVal = ISD::isTrueWhenEqual(Cond) ? -1 : 0;
|
||||
break;
|
||||
}
|
||||
|
||||
// We can always fold X == X for integer setcc's.
|
||||
if (N0.getValueType().isInteger()) {
|
||||
return DAG.getConstant(EqVal, VT);
|
||||
}
|
||||
unsigned UOF = ISD::getUnorderedFlavor(Cond);
|
||||
if (UOF == 2) // FP operators that are undefined on NaNs.
|
||||
return DAG.getConstant(ISD::isTrueWhenEqual(Cond), VT);
|
||||
return DAG.getConstant(EqVal, VT);
|
||||
if (UOF == unsigned(ISD::isTrueWhenEqual(Cond)))
|
||||
return DAG.getConstant(UOF, VT);
|
||||
return DAG.getConstant(EqVal, VT);
|
||||
// Otherwise, we can't fold it. However, we can simplify it to SETUO/SETO
|
||||
// if it is not already.
|
||||
ISD::CondCode NewCond = UOF == 0 ? ISD::SETO : ISD::SETUO;
|
||||
|
55
test/CodeGen/X86/sext-setcc-self.ll
Normal file
55
test/CodeGen/X86/sext-setcc-self.ll
Normal file
@ -0,0 +1,55 @@
|
||||
; RUN: llc -march=x86 -mcpu=nehalem < %s | FileCheck %s
|
||||
|
||||
define <4 x i32> @test_ueq(<4 x float> %in) {
|
||||
entry:
|
||||
; CHECK: pcmpeqd %xmm0, %xmm0
|
||||
; CHECK-NEXT: ret
|
||||
%0 = fcmp ueq <4 x float> %in, %in
|
||||
%1 = sext <4 x i1> %0 to <4 x i32>
|
||||
ret <4 x i32> %1
|
||||
}
|
||||
|
||||
define <4 x i32> @test_uge(<4 x float> %in) {
|
||||
entry:
|
||||
; CHECK: pcmpeqd %xmm0, %xmm0
|
||||
; CHECK-NEXT: ret
|
||||
%0 = fcmp uge <4 x float> %in, %in
|
||||
%1 = sext <4 x i1> %0 to <4 x i32>
|
||||
ret <4 x i32> %1
|
||||
}
|
||||
|
||||
define <4 x i32> @test_ule(<4 x float> %in) {
|
||||
entry:
|
||||
; CHECK: pcmpeqd %xmm0, %xmm0
|
||||
; CHECK-NEXT: ret
|
||||
%0 = fcmp ule <4 x float> %in, %in
|
||||
%1 = sext <4 x i1> %0 to <4 x i32>
|
||||
ret <4 x i32> %1
|
||||
}
|
||||
|
||||
define <4 x i32> @test_one(<4 x float> %in) {
|
||||
entry:
|
||||
; CHECK: xorps %xmm0, %xmm0
|
||||
; CHECK-NEXT: ret
|
||||
%0 = fcmp one <4 x float> %in, %in
|
||||
%1 = sext <4 x i1> %0 to <4 x i32>
|
||||
ret <4 x i32> %1
|
||||
}
|
||||
|
||||
define <4 x i32> @test_ogt(<4 x float> %in) {
|
||||
entry:
|
||||
; CHECK: xorps %xmm0, %xmm0
|
||||
; CHECK-NEXT: ret
|
||||
%0 = fcmp ogt <4 x float> %in, %in
|
||||
%1 = sext <4 x i1> %0 to <4 x i32>
|
||||
ret <4 x i32> %1
|
||||
}
|
||||
|
||||
define <4 x i32> @test_olt(<4 x float> %in) {
|
||||
entry:
|
||||
; CHECK: xorps %xmm0, %xmm0
|
||||
; CHECK-NEXT: ret
|
||||
%0 = fcmp olt <4 x float> %in, %in
|
||||
%1 = sext <4 x i1> %0 to <4 x i32>
|
||||
ret <4 x i32> %1
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user