mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 12:12:47 +01:00
Do not lower VSETCC if operand is an f16 vector
Summary: SETCC with f16 vectors has OperationAction set to Expand but still gets lowered to FCM* intrinsics based on its result type. This patch skips lowering of VSETCC if the operand is an f16 vector. v4 and v8 tests included. Reviewers: ab, jmolloy Subscribers: srhines, llvm-commits Differential Revision: http://reviews.llvm.org/D15361 llvm-svn: 258471
This commit is contained in:
parent
2ddae2ea6b
commit
2e5b2b3d41
@ -6689,6 +6689,9 @@ SDValue AArch64TargetLowering::LowerVSETCC(SDValue Op,
|
||||
return DAG.getSExtOrTrunc(Cmp, dl, Op.getValueType());
|
||||
}
|
||||
|
||||
if (LHS.getValueType().getVectorElementType() == MVT::f16)
|
||||
return SDValue();
|
||||
|
||||
assert(LHS.getValueType().getVectorElementType() == MVT::f32 ||
|
||||
LHS.getValueType().getVectorElementType() == MVT::f64);
|
||||
|
||||
|
@ -267,4 +267,278 @@ define <4 x i16> @fptoui_i16(<4 x half> %a) #0 {
|
||||
ret <4 x i16> %1
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
; CHECK-LABEL: test_fcmp_une:
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, ne
|
||||
; CHECK-DAG: csel {{.*}}, wzr, ne
|
||||
; CHECK-DAG: csel {{.*}}, wzr, ne
|
||||
; CHECK-DAG: csel {{.*}}, wzr, ne
|
||||
define <4 x i1> @test_fcmp_une(<4 x half> %a, <4 x half> %b) #0 {
|
||||
%1 = fcmp une <4 x half> %a, %b
|
||||
ret <4 x i1> %1
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
; CHECK-LABEL: test_fcmp_ueq:
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, eq
|
||||
; CHECK-DAG: csel {{.*}}, wzr, eq
|
||||
; CHECK-DAG: csel {{.*}}, wzr, eq
|
||||
; CHECK-DAG: csel {{.*}}, wzr, eq
|
||||
; CHECK-DAG: csel {{.*}}, vs
|
||||
; CHECK-DAG: csel {{.*}}, vs
|
||||
; CHECK-DAG: csel {{.*}}, vs
|
||||
; CHECK-DAG: csel {{.*}}, vs
|
||||
define <4 x i1> @test_fcmp_ueq(<4 x half> %a, <4 x half> %b) #0 {
|
||||
%1 = fcmp ueq <4 x half> %a, %b
|
||||
ret <4 x i1> %1
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
; CHECK-LABEL: test_fcmp_ugt:
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, hi
|
||||
; CHECK-DAG: csel {{.*}}, wzr, hi
|
||||
; CHECK-DAG: csel {{.*}}, wzr, hi
|
||||
; CHECK-DAG: csel {{.*}}, wzr, hi
|
||||
define <4 x i1> @test_fcmp_ugt(<4 x half> %a, <4 x half> %b) #0 {
|
||||
%1 = fcmp ugt <4 x half> %a, %b
|
||||
ret <4 x i1> %1
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
; CHECK-LABEL: test_fcmp_uge:
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, pl
|
||||
; CHECK-DAG: csel {{.*}}, wzr, pl
|
||||
; CHECK-DAG: csel {{.*}}, wzr, pl
|
||||
; CHECK-DAG: csel {{.*}}, wzr, pl
|
||||
define <4 x i1> @test_fcmp_uge(<4 x half> %a, <4 x half> %b) #0 {
|
||||
%1 = fcmp uge <4 x half> %a, %b
|
||||
ret <4 x i1> %1
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
; CHECK-LABEL: test_fcmp_ult:
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, lt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, lt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, lt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, lt
|
||||
define <4 x i1> @test_fcmp_ult(<4 x half> %a, <4 x half> %b) #0 {
|
||||
%1 = fcmp ult <4 x half> %a, %b
|
||||
ret <4 x i1> %1
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
; CHECK-LABEL: test_fcmp_ule:
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, le
|
||||
; CHECK-DAG: csel {{.*}}, wzr, le
|
||||
; CHECK-DAG: csel {{.*}}, wzr, le
|
||||
; CHECK-DAG: csel {{.*}}, wzr, le
|
||||
define <4 x i1> @test_fcmp_ule(<4 x half> %a, <4 x half> %b) #0 {
|
||||
%1 = fcmp ule <4 x half> %a, %b
|
||||
ret <4 x i1> %1
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
; CHECK-LABEL: test_fcmp_uno:
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, vs
|
||||
; CHECK-DAG: csel {{.*}}, wzr, vs
|
||||
; CHECK-DAG: csel {{.*}}, wzr, vs
|
||||
; CHECK-DAG: csel {{.*}}, wzr, vs
|
||||
define <4 x i1> @test_fcmp_uno(<4 x half> %a, <4 x half> %b) #0 {
|
||||
%1 = fcmp uno <4 x half> %a, %b
|
||||
ret <4 x i1> %1
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
; CHECK-LABEL: test_fcmp_one:
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, mi
|
||||
; CHECK-DAG: csel {{.*}}, wzr, mi
|
||||
; CHECK-DAG: csel {{.*}}, wzr, mi
|
||||
; CHECK-DAG: csel {{.*}}, wzr, mi
|
||||
; CHECK-DAG: csel {{.*}}, gt
|
||||
; CHECK-DAG: csel {{.*}}, gt
|
||||
; CHECK-DAG: csel {{.*}}, gt
|
||||
; CHECK-DAG: csel {{.*}}, gt
|
||||
define <4 x i1> @test_fcmp_one(<4 x half> %a, <4 x half> %b) #0 {
|
||||
%1 = fcmp one <4 x half> %a, %b
|
||||
ret <4 x i1> %1
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
; CHECK-LABEL: test_fcmp_oeq:
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, eq
|
||||
; CHECK-DAG: csel {{.*}}, wzr, eq
|
||||
; CHECK-DAG: csel {{.*}}, wzr, eq
|
||||
; CHECK-DAG: csel {{.*}}, wzr, eq
|
||||
define <4 x i1> @test_fcmp_oeq(<4 x half> %a, <4 x half> %b) #0 {
|
||||
%1 = fcmp oeq <4 x half> %a, %b
|
||||
ret <4 x i1> %1
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
; CHECK-LABEL: test_fcmp_ogt:
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, gt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, gt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, gt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, gt
|
||||
define <4 x i1> @test_fcmp_ogt(<4 x half> %a, <4 x half> %b) #0 {
|
||||
%1 = fcmp ogt <4 x half> %a, %b
|
||||
ret <4 x i1> %1
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
; CHECK-LABEL: test_fcmp_oge:
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, ge
|
||||
; CHECK-DAG: csel {{.*}}, wzr, ge
|
||||
; CHECK-DAG: csel {{.*}}, wzr, ge
|
||||
; CHECK-DAG: csel {{.*}}, wzr, ge
|
||||
define <4 x i1> @test_fcmp_oge(<4 x half> %a, <4 x half> %b) #0 {
|
||||
%1 = fcmp oge <4 x half> %a, %b
|
||||
ret <4 x i1> %1
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
; CHECK-LABEL: test_fcmp_olt:
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, mi
|
||||
; CHECK-DAG: csel {{.*}}, wzr, mi
|
||||
; CHECK-DAG: csel {{.*}}, wzr, mi
|
||||
; CHECK-DAG: csel {{.*}}, wzr, mi
|
||||
define <4 x i1> @test_fcmp_olt(<4 x half> %a, <4 x half> %b) #0 {
|
||||
%1 = fcmp olt <4 x half> %a, %b
|
||||
ret <4 x i1> %1
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
; CHECK-LABEL: test_fcmp_ole:
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, ls
|
||||
; CHECK-DAG: csel {{.*}}, wzr, ls
|
||||
; CHECK-DAG: csel {{.*}}, wzr, ls
|
||||
; CHECK-DAG: csel {{.*}}, wzr, ls
|
||||
define <4 x i1> @test_fcmp_ole(<4 x half> %a, <4 x half> %b) #0 {
|
||||
%1 = fcmp ole <4 x half> %a, %b
|
||||
ret <4 x i1> %1
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind readnone
|
||||
; CHECK-LABEL: test_fcmp_ord:
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: fcvt
|
||||
; CHECK-DAG: csel {{.*}}, wzr, vc
|
||||
; CHECK-DAG: csel {{.*}}, wzr, vc
|
||||
; CHECK-DAG: csel {{.*}}, wzr, vc
|
||||
; CHECK-DAG: csel {{.*}}, wzr, vc
|
||||
define <4 x i1> @test_fcmp_ord(<4 x half> %a, <4 x half> %b) #0 {
|
||||
%1 = fcmp ord <4 x half> %a, %b
|
||||
ret <4 x i1> %1
|
||||
}
|
||||
|
||||
attributes #0 = { nounwind }
|
||||
|
@ -421,4 +421,88 @@ define <8 x i16> @fptoui_i16(<8 x half> %a) #0 {
|
||||
ret <8 x i16> %1
|
||||
}
|
||||
|
||||
; FileCheck checks are unwieldy with 16 fcvt and 8 csel tests. Skipped.
|
||||
define <8 x i1> @test_fcmp_une(<8 x half> %a, <8 x half> %b) #0 {
|
||||
%1 = fcmp une <8 x half> %a, %b
|
||||
ret <8 x i1> %1
|
||||
}
|
||||
|
||||
; FileCheck checks are unwieldy with 16 fcvt and 16 csel tests. Skipped.
|
||||
define <8 x i1> @test_fcmp_ueq(<8 x half> %a, <8 x half> %b) #0 {
|
||||
%1 = fcmp ueq <8 x half> %a, %b
|
||||
ret <8 x i1> %1
|
||||
}
|
||||
|
||||
; FileCheck checks are unwieldy with 16 fcvt and 8 csel tests. Skipped.
|
||||
define <8 x i1> @test_fcmp_ugt(<8 x half> %a, <8 x half> %b) #0 {
|
||||
%1 = fcmp ugt <8 x half> %a, %b
|
||||
ret <8 x i1> %1
|
||||
}
|
||||
|
||||
; FileCheck checks are unwieldy with 16 fcvt and 8 csel tests. Skipped.
|
||||
define <8 x i1> @test_fcmp_uge(<8 x half> %a, <8 x half> %b) #0 {
|
||||
%1 = fcmp uge <8 x half> %a, %b
|
||||
ret <8 x i1> %1
|
||||
}
|
||||
|
||||
; FileCheck checks are unwieldy with 16 fcvt and 8 csel tests. Skipped.
|
||||
define <8 x i1> @test_fcmp_ult(<8 x half> %a, <8 x half> %b) #0 {
|
||||
%1 = fcmp ult <8 x half> %a, %b
|
||||
ret <8 x i1> %1
|
||||
}
|
||||
|
||||
; FileCheck checks are unwieldy with 16 fcvt and 8 csel tests. Skipped.
|
||||
define <8 x i1> @test_fcmp_ule(<8 x half> %a, <8 x half> %b) #0 {
|
||||
%1 = fcmp ule <8 x half> %a, %b
|
||||
ret <8 x i1> %1
|
||||
}
|
||||
|
||||
; FileCheck checks are unwieldy with 16 fcvt and 8 csel tests. Skipped.
|
||||
define <8 x i1> @test_fcmp_uno(<8 x half> %a, <8 x half> %b) #0 {
|
||||
%1 = fcmp uno <8 x half> %a, %b
|
||||
ret <8 x i1> %1
|
||||
}
|
||||
|
||||
; FileCheck checks are unwieldy with 16 fcvt and 8 csel tests. Skipped.
|
||||
define <8 x i1> @test_fcmp_one(<8 x half> %a, <8 x half> %b) #0 {
|
||||
%1 = fcmp one <8 x half> %a, %b
|
||||
ret <8 x i1> %1
|
||||
}
|
||||
|
||||
; FileCheck checks are unwieldy with 16 fcvt and 8 csel tests. Skipped.
|
||||
define <8 x i1> @test_fcmp_oeq(<8 x half> %a, <8 x half> %b) #0 {
|
||||
%1 = fcmp oeq <8 x half> %a, %b
|
||||
ret <8 x i1> %1
|
||||
}
|
||||
|
||||
; FileCheck checks are unwieldy with 16 fcvt and 8 csel tests. Skipped.
|
||||
define <8 x i1> @test_fcmp_ogt(<8 x half> %a, <8 x half> %b) #0 {
|
||||
%1 = fcmp ogt <8 x half> %a, %b
|
||||
ret <8 x i1> %1
|
||||
}
|
||||
|
||||
; FileCheck checks are unwieldy with 16 fcvt and 8 csel tests. Skipped.
|
||||
define <8 x i1> @test_fcmp_oge(<8 x half> %a, <8 x half> %b) #0 {
|
||||
%1 = fcmp oge <8 x half> %a, %b
|
||||
ret <8 x i1> %1
|
||||
}
|
||||
|
||||
; FileCheck checks are unwieldy with 16 fcvt and 8 csel tests. Skipped.
|
||||
define <8 x i1> @test_fcmp_olt(<8 x half> %a, <8 x half> %b) #0 {
|
||||
%1 = fcmp olt <8 x half> %a, %b
|
||||
ret <8 x i1> %1
|
||||
}
|
||||
|
||||
; FileCheck checks are unwieldy with 16 fcvt and 8 csel tests. Skipped.
|
||||
define <8 x i1> @test_fcmp_ole(<8 x half> %a, <8 x half> %b) #0 {
|
||||
%1 = fcmp ole <8 x half> %a, %b
|
||||
ret <8 x i1> %1
|
||||
}
|
||||
|
||||
; FileCheck checks are unwieldy with 16 fcvt and 8 csel tests. Skipped.
|
||||
define <8 x i1> @test_fcmp_ord(<8 x half> %a, <8 x half> %b) #0 {
|
||||
%1 = fcmp ord <8 x half> %a, %b
|
||||
ret <8 x i1> %1
|
||||
}
|
||||
|
||||
attributes #0 = { nounwind }
|
||||
|
Loading…
Reference in New Issue
Block a user