diff options
author | Craig Topper <craig.topper@sifive.com> | 2025-08-05 16:12:42 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2025-08-05 16:12:42 -0700 |
commit | 73685583c859deae7b30bb01692670fd7356c7db (patch) | |
tree | d508682b44e16bbcc0e43e4ea2bb7549c0416fa2 /llvm/lib/IR/IntrinsicInst.cpp | |
parent | 64eba6ef9610a4a82e1610ecd806b8488144bad0 (diff) | |
download | llvm-73685583c859deae7b30bb01692670fd7356c7db.zip llvm-73685583c859deae7b30bb01692670fd7356c7db.tar.gz llvm-73685583c859deae7b30bb01692670fd7356c7db.tar.bz2 |
[VP][RISCV] Add a vp.load.ff intrinsic for fault only first load. (#128593)
There's been some interest in supporting early-exit loops recently.
https://discourse.llvm.org/t/rfc-supporting-more-early-exit-loops/84690
This patch was extracted from our downstream where we've been using it
in our vectorizer.
Diffstat (limited to 'llvm/lib/IR/IntrinsicInst.cpp')
-rw-r--r-- | llvm/lib/IR/IntrinsicInst.cpp | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/llvm/lib/IR/IntrinsicInst.cpp b/llvm/lib/IR/IntrinsicInst.cpp index b1d3339c..23a4d1b 100644 --- a/llvm/lib/IR/IntrinsicInst.cpp +++ b/llvm/lib/IR/IntrinsicInst.cpp @@ -448,6 +448,7 @@ VPIntrinsic::getMemoryPointerParamPos(Intrinsic::ID VPID) { case Intrinsic::experimental_vp_strided_store: return 1; case Intrinsic::vp_load: + case Intrinsic::vp_load_ff: case Intrinsic::vp_gather: case Intrinsic::experimental_vp_strided_load: return 0; @@ -671,6 +672,10 @@ Function *VPIntrinsic::getOrInsertDeclarationForParams( VPFunc = Intrinsic::getOrInsertDeclaration( M, VPID, {ReturnType, Params[0]->getType()}); break; + case Intrinsic::vp_load_ff: + VPFunc = Intrinsic::getOrInsertDeclaration( + M, VPID, {ReturnType->getStructElementType(0), Params[0]->getType()}); + break; case Intrinsic::experimental_vp_strided_load: VPFunc = Intrinsic::getOrInsertDeclaration( M, VPID, {ReturnType, Params[0]->getType(), Params[1]->getType()}); |