[llvm] c1c4251 - [SandboxVec] Early return checks (#107465)
via llvm-commits
llvm-commits at lists.llvm.org
Thu Sep 5 15:25:53 PDT 2024
Author: vporpo
Date: 2024-09-05T15:25:50-07:00
New Revision: c1c42518c1356e78a10bf252a4a5a643b2bb9efd
URL: https://github.com/llvm/llvm-project/commit/c1c42518c1356e78a10bf252a4a5a643b2bb9efd
DIFF: https://github.com/llvm/llvm-project/commit/c1c42518c1356e78a10bf252a4a5a643b2bb9efd.diff
LOG: [SandboxVec] Early return checks (#107465)
This patch implements a couple of early return checks.
Added:
llvm/test/Transforms/SandboxVectorizer/X86/no_implicit_float.ll
Modified:
llvm/lib/Transforms/Vectorize/SandboxVectorizer/SandboxVectorizer.cpp
Removed:
################################################################################
diff --git a/llvm/lib/Transforms/Vectorize/SandboxVectorizer/SandboxVectorizer.cpp b/llvm/lib/Transforms/Vectorize/SandboxVectorizer/SandboxVectorizer.cpp
index ec4bfbb56ecb48..e9be6f5283fea7 100644
--- a/llvm/lib/Transforms/Vectorize/SandboxVectorizer/SandboxVectorizer.cpp
+++ b/llvm/lib/Transforms/Vectorize/SandboxVectorizer/SandboxVectorizer.cpp
@@ -29,7 +29,18 @@ PreservedAnalyses SandboxVectorizerPass::run(Function &F,
}
bool SandboxVectorizerPass::runImpl(Function &F) {
+ // If the target claims to have no vector registers early return.
+ if (!TTI->getNumberOfRegisters(TTI->getRegisterClassForType(true))) {
+ LLVM_DEBUG(dbgs() << "SBVec: Target has no vector registers, return.\n");
+ return false;
+ }
LLVM_DEBUG(dbgs() << "SBVec: Analyzing " << F.getName() << ".\n");
+ // Early return if the attribute NoImplicitFloat is used.
+ if (F.hasFnAttribute(Attribute::NoImplicitFloat)) {
+ LLVM_DEBUG(dbgs() << "SBVec: NoImplicitFloat attribute, return.\n");
+ return false;
+ }
+
sandboxir::Context Ctx(F.getContext());
// Create SandboxIR for `F`.
sandboxir::Function &SBF = *Ctx.createFunction(&F);
diff --git a/llvm/test/Transforms/SandboxVectorizer/X86/no_implicit_float.ll b/llvm/test/Transforms/SandboxVectorizer/X86/no_implicit_float.ll
new file mode 100644
index 00000000000000..37fc03cb311661
--- /dev/null
+++ b/llvm/test/Transforms/SandboxVectorizer/X86/no_implicit_float.ll
@@ -0,0 +1,23 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
+; RUN: opt -passes=sandbox-vectorizer -mtriple=x86_64-- -mattr=+avx %s -S | FileCheck %s
+
+; Check that we don't vectorize a NoImplicitFloat function.
+define void @no_implicit_float(ptr %ptr) noimplicitfloat {
+; CHECK-LABEL: define void @no_implicit_float(
+; CHECK-SAME: ptr [[PTR:%.*]]) #[[ATTR0:[0-9]+]] {
+; CHECK-NEXT: [[PTR0:%.*]] = getelementptr double, ptr [[PTR]], i32 0
+; CHECK-NEXT: [[PTR1:%.*]] = getelementptr double, ptr [[PTR]], i32 1
+; CHECK-NEXT: [[LD0:%.*]] = load double, ptr [[PTR0]], align 8
+; CHECK-NEXT: [[LD1:%.*]] = load double, ptr [[PTR1]], align 8
+; CHECK-NEXT: store double [[LD0]], ptr [[PTR0]], align 8
+; CHECK-NEXT: store double [[LD1]], ptr [[PTR1]], align 8
+; CHECK-NEXT: ret void
+;
+ %ptr0 = getelementptr double, ptr %ptr, i32 0
+ %ptr1 = getelementptr double, ptr %ptr, i32 1
+ %ld0 = load double, ptr %ptr0
+ %ld1 = load double, ptr %ptr1
+ store double %ld0, ptr %ptr0
+ store double %ld1, ptr %ptr1
+ ret void
+}
More information about the llvm-commits
mailing list