aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib
diff options
context:
space:
mode:
authorBenjamin Maxwell <benjamin.maxwell@arm.com>2025-11-06 13:33:55 +0000
committerGitHub <noreply@github.com>2025-11-06 13:33:55 +0000
commitcbb9b0e08ed19b074ff594a1306c3ca3cb8b9913 (patch)
treee2a7b5164c423a697c298a368d753a2e574fb854 /llvm/lib
parente974c65774414eceaf789e2464f56e39c9afc210 (diff)
downloadllvm-cbb9b0e08ed19b074ff594a1306c3ca3cb8b9913.zip
llvm-cbb9b0e08ed19b074ff594a1306c3ca3cb8b9913.tar.gz
llvm-cbb9b0e08ed19b074ff594a1306c3ca3cb8b9913.tar.bz2
[AArch64] Lower v1i64 and v2i64 [S|U][MIN|MAX] to SVE when available (#166735)
The predicate is likely to be hoisted, so in a loop, this would result in a single SVE instruction, which should have lower latency.
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Target/AArch64/AArch64ISelLowering.cpp5
1 files changed, 3 insertions, 2 deletions
diff --git a/llvm/lib/Target/AArch64/AArch64ISelLowering.cpp b/llvm/lib/Target/AArch64/AArch64ISelLowering.cpp
index d08f9b9..5defd48 100644
--- a/llvm/lib/Target/AArch64/AArch64ISelLowering.cpp
+++ b/llvm/lib/Target/AArch64/AArch64ISelLowering.cpp
@@ -11330,9 +11330,10 @@ SDValue AArch64TargetLowering::LowerMinMax(SDValue Op,
break;
}
+ // Note: This lowering only overrides NEON for v1i64 and v2i64, where we
+ // prefer using SVE if available.
if (VT.isScalableVector() ||
- useSVEForFixedLengthVectorVT(
- VT, /*OverrideNEON=*/Subtarget->useSVEForFixedLengthVectors())) {
+ useSVEForFixedLengthVectorVT(VT, /*OverrideNEON=*/true)) {
switch (Opcode) {
default:
llvm_unreachable("Wrong instruction");