From b8b1b96bd7419c1561089e89dbee4b8681634ed2 Mon Sep 17 00:00:00 2001 From: Marcos Maronas Date: Fri, 13 Dec 2024 16:31:43 -0800 Subject: [PATCH] Add cmake option to enable --spirv-tools-dis feature (#2925) --- CMakeLists.txt | 4 +++- README.md | 1 + test/CMakeLists.txt | 3 +++ test/lit.cfg.py | 2 +- test/lit.site.cfg.py.in | 1 + tools/llvm-spirv/CMakeLists.txt | 4 ++-- 6 files changed, 11 insertions(+), 4 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 786ea78a9..e8eae2484 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -144,7 +144,9 @@ if (NOT SPIRV_TOOLS_FOUND) endif() endif() -if (NOT SPIRV_TOOLS_FOUND) +option(LLVM_SPIRV_ENABLE_LIBSPIRV_DIS "Enable --spirv-tools-dis support.") + +if (NOT SPIRV_TOOLS_FOUND AND LLVM_SPIRV_ENABLE_LIBSPIRV_DIS) message(STATUS "SPIRV-Tools not found; project will be built without " "--spirv-tools-dis support.") endif() diff --git a/README.md b/README.md index 803cfe366..baa0ebc2d 100644 --- a/README.md +++ b/README.md @@ -97,6 +97,7 @@ Building clang from sources takes time and resources and it can be avoided: ### Build with SPIRV-Tools The translator can use [SPIRV-Tools](https://github.com/KhronosGroup/SPIRV-Tools) to generate assembly with widely adopted syntax. +This feature can be enabled by passing `-DLLVM_SPIRV_ENABLE_LIBSPIRV_DIS=ON` option. If SPIRV-Tools have been installed prior to the build it will be detected and used automatically. However it is also possible to enable use of SPIRV-Tools from a custom location using the following instructions: diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index 2fa999e51..1e51c5059 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -31,6 +31,9 @@ if(SPIRV_TOOLS_FOUND AND NOT SPIRV-Tools-tools_FOUND) endif() set(SPIRV_TOOLS_BINDIR "${SPIRV_TOOLS_PREFIX}/bin") + if (LLVM_SPIRV_ENABLE_LIBSPIRV_DIS) + set(SPIRV_ENABLE_LIBSPIRV_DIS ON) + endif() elseif(SPIRV-Tools-tools_FOUND) # we found SPIRV-Tools via cmake targets diff --git a/test/lit.cfg.py b/test/lit.cfg.py index 2d5d30e0a..b56953aa5 100644 --- a/test/lit.cfg.py +++ b/test/lit.cfg.py @@ -21,7 +21,7 @@ # excludes: A list of directories and fles to exclude from the testsuite. config.excludes = ['CMakeLists.txt'] -if config.spirv_tools_found: +if config.libspirv_dis: config.available_features.add('libspirv_dis') if not config.spirv_skip_debug_info_tests: diff --git a/test/lit.site.cfg.py.in b/test/lit.site.cfg.py.in index a47fb197c..f7a23ce58 100644 --- a/test/lit.site.cfg.py.in +++ b/test/lit.site.cfg.py.in @@ -19,6 +19,7 @@ config.host_arch = "@HOST_ARCH@" config.python_executable = "@PYTHON_EXECUTABLE@" config.test_run_dir = "@CMAKE_CURRENT_BINARY_DIR@" config.spirv_tools_found = "@SPIRV_TOOLS_FOUND@" +config.libspirv_dis = "@SPIRV_ENABLE_LIBSPIRV_DIS@" config.spirv_tools_have_spirv_as = @SPIRV_TOOLS_SPIRV_AS_FOUND@ config.spirv_tools_have_spirv_dis = @SPIRV_TOOLS_SPIRV_DIS_FOUND@ config.spirv_tools_have_spirv_link = @SPIRV_TOOLS_SPIRV_LINK_FOUND@ diff --git a/tools/llvm-spirv/CMakeLists.txt b/tools/llvm-spirv/CMakeLists.txt index 9685d7790..a7e48ba8a 100644 --- a/tools/llvm-spirv/CMakeLists.txt +++ b/tools/llvm-spirv/CMakeLists.txt @@ -32,8 +32,8 @@ target_include_directories(llvm-spirv ${LLVM_SPIRV_INCLUDE_DIRS} ) -if(SPIRV_TOOLS_FOUND) +if(SPIRV_TOOLS_FOUND AND LLVM_SPIRV_ENABLE_LIBSPIRV_DIS) target_compile_definitions(llvm-spirv PRIVATE LLVM_SPIRV_HAVE_SPIRV_TOOLS=1) target_include_directories(llvm-spirv PRIVATE ${SPIRV_TOOLS_INCLUDE_DIRS}) target_link_libraries(llvm-spirv PRIVATE ${SPIRV_TOOLS_LDFLAGS}) -endif(SPIRV_TOOLS_FOUND) +endif()