[llvm] [X86] Check that the type is integer before calling isUnsignedIntSetCC in combineExtSetcc. (PR #128263)
Craig Topper via llvm-commits
llvm-commits at lists.llvm.org
Fri Feb 21 17:22:57 PST 2025
https://github.com/topperc created https://github.com/llvm/llvm-project/pull/128263
SETULT can be an unsigned less than integer compare or a unordered less than FP compare. We need to check the VT to distinguish them.
Fixes on of the issues from #128237.
>From ddd97716acea944c44263d495b805cfcb79deaf2 Mon Sep 17 00:00:00 2001
From: Craig Topper <craig.topper at sifive.com>
Date: Fri, 21 Feb 2025 17:19:43 -0800
Subject: [PATCH] [X86] Check that the type is integer before calling
isUnsignedIntSetCC in combineExtSetcc.
SETULT can be an unsigned integer compare or a unordered less than
FP compare. We need to check the VT to distinquish them.
Fixes on of the issues from #128237.
---
llvm/lib/Target/X86/X86ISelLowering.cpp | 5 +++--
llvm/test/CodeGen/X86/v8i1-masks.ll | 12 ++++--------
2 files changed, 7 insertions(+), 10 deletions(-)
diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp
index f8f7d3e367896..3e81c3f3ed871 100644
--- a/llvm/lib/Target/X86/X86ISelLowering.cpp
+++ b/llvm/lib/Target/X86/X86ISelLowering.cpp
@@ -55331,14 +55331,15 @@ static SDValue combineExtSetcc(SDNode *N, SelectionDAG &DAG,
if (Size > 256 && Subtarget.useAVX512Regs())
return SDValue();
+ EVT N00VT = N0.getOperand(0).getValueType();
+
// Don't fold if the condition code can't be handled by PCMPEQ/PCMPGT since
// that's the only integer compares with we have.
ISD::CondCode CC = cast<CondCodeSDNode>(N0.getOperand(2))->get();
- if (ISD::isUnsignedIntSetCC(CC))
+ if (N00VT.isInteger() && ISD::isUnsignedIntSetCC(CC))
return SDValue();
// Only do this combine if the extension will be fully consumed by the setcc.
- EVT N00VT = N0.getOperand(0).getValueType();
EVT MatchingVecType = N00VT.changeVectorElementTypeToInteger();
if (Size != MatchingVecType.getSizeInBits())
return SDValue();
diff --git a/llvm/test/CodeGen/X86/v8i1-masks.ll b/llvm/test/CodeGen/X86/v8i1-masks.ll
index 67b7eb48e4cb3..01f10372eaa2d 100644
--- a/llvm/test/CodeGen/X86/v8i1-masks.ll
+++ b/llvm/test/CodeGen/X86/v8i1-masks.ll
@@ -150,10 +150,8 @@ define void @neg_masks(ptr %a, ptr %b, ptr %c) nounwind uwtable noinline ssp {
; X86-AVX512-NEXT: movl {{[0-9]+}}(%esp), %eax
; X86-AVX512-NEXT: movl {{[0-9]+}}(%esp), %ecx
; X86-AVX512-NEXT: vmovups (%ecx), %ymm0
-; X86-AVX512-NEXT: vcmpnltps (%eax), %ymm0, %k1
-; X86-AVX512-NEXT: vpcmpeqd %ymm0, %ymm0, %ymm0
-; X86-AVX512-NEXT: vmovdqa32 %ymm0, %ymm0 {%k1} {z}
-; X86-AVX512-NEXT: vpsrld $31, %ymm0, %ymm0
+; X86-AVX512-NEXT: vcmpnltps (%eax), %ymm0, %ymm0
+; X86-AVX512-NEXT: vpandd {{\.?LCPI[0-9]+_[0-9]+}}{1to8}, %ymm0, %ymm0
; X86-AVX512-NEXT: vmovdqa %ymm0, (%eax)
; X86-AVX512-NEXT: vzeroupper
; X86-AVX512-NEXT: retl
@@ -161,10 +159,8 @@ define void @neg_masks(ptr %a, ptr %b, ptr %c) nounwind uwtable noinline ssp {
; X64-AVX512-LABEL: neg_masks:
; X64-AVX512: ## %bb.0:
; X64-AVX512-NEXT: vmovups (%rsi), %ymm0
-; X64-AVX512-NEXT: vcmpnltps (%rdi), %ymm0, %k1
-; X64-AVX512-NEXT: vpcmpeqd %ymm0, %ymm0, %ymm0
-; X64-AVX512-NEXT: vmovdqa32 %ymm0, %ymm0 {%k1} {z}
-; X64-AVX512-NEXT: vpsrld $31, %ymm0, %ymm0
+; X64-AVX512-NEXT: vcmpnltps (%rdi), %ymm0, %ymm0
+; X64-AVX512-NEXT: vpandd {{\.?LCPI[0-9]+_[0-9]+}}(%rip){1to8}, %ymm0, %ymm0
; X64-AVX512-NEXT: vmovdqa %ymm0, (%rax)
; X64-AVX512-NEXT: vzeroupper
; X64-AVX512-NEXT: retq
More information about the llvm-commits
mailing list