[llvm] 832cd2d - [SPIRV] Add option to add all KHR extensions (#145535)
via llvm-commits
llvm-commits at lists.llvm.org
Wed Jul 2 10:50:52 PDT 2025
Author: Steven Perron
Date: 2025-07-02T13:50:48-04:00
New Revision: 832cd2df0b564a0643784d647dd55372c80fdb6c
URL: https://github.com/llvm/llvm-project/commit/832cd2df0b564a0643784d647dd55372c80fdb6c
DIFF: https://github.com/llvm/llvm-project/commit/832cd2df0b564a0643784d647dd55372c80fdb6c.diff
LOG: [SPIRV] Add option to add all KHR extensions (#145535)
In DXC, there is an option to enable all KHR extension. I would like to
extend the existing `-spirv-ext` backend commandline option to have the
same capability. It is like the special case for `all` execept it only
adds the `SPV_KHR_*` extensions.
Part of https://github.com/llvm/llvm-project/issues/137650.
Added:
Modified:
llvm/lib/Target/SPIRV/SPIRVCommandLine.cpp
llvm/test/CodeGen/SPIRV/extensions/enable-all-extensions-but-one.ll
Removed:
################################################################################
diff --git a/llvm/lib/Target/SPIRV/SPIRVCommandLine.cpp b/llvm/lib/Target/SPIRV/SPIRVCommandLine.cpp
index 1d19bc4617c7d..2726203d253ad 100644
--- a/llvm/lib/Target/SPIRV/SPIRVCommandLine.cpp
+++ b/llvm/lib/Target/SPIRV/SPIRVCommandLine.cpp
@@ -121,6 +121,13 @@ bool SPIRVExtensionsParser::parse(cl::Option &O, StringRef ArgName,
continue;
}
+ if (Token.size() == 3 && Token.upper() == "KHR") {
+ for (const auto &[ExtensionName, ExtensionEnum] : SPIRVExtensionMap)
+ if (StringRef(ExtensionName).starts_with("SPV_KHR_"))
+ EnabledExtensions.insert(ExtensionEnum);
+ continue;
+ }
+
if (Token.empty() || (!Token.starts_with("+") && !Token.starts_with("-")))
return O.error("Invalid extension list format: " + Token.str());
diff --git a/llvm/test/CodeGen/SPIRV/extensions/enable-all-extensions-but-one.ll b/llvm/test/CodeGen/SPIRV/extensions/enable-all-extensions-but-one.ll
index 02d21a1abafa5..4db0ba33d52c9 100644
--- a/llvm/test/CodeGen/SPIRV/extensions/enable-all-extensions-but-one.ll
+++ b/llvm/test/CodeGen/SPIRV/extensions/enable-all-extensions-but-one.ll
@@ -1,4 +1,6 @@
; RUN: llc -verify-machineinstrs -O0 -mtriple=spirv32-unknown-unknown --spirv-ext=all,-SPV_INTEL_arbitrary_precision_integers %s -o - | FileCheck %s
+; RUN: llc -verify-machineinstrs -O0 -mtriple=spirv32-unknown-unknown --spirv-ext=KHR %s -o - | FileCheck %s
+; RUN: llc -verify-machineinstrs -O0 -mtriple=spirv32-unknown-unknown --spirv-ext=khr %s -o - | FileCheck %s
define i6 @foo() {
%call = tail call i32 @llvm.bitreverse.i32(i32 42)
More information about the llvm-commits
mailing list