You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
192 lines
5.5 KiB
192 lines
5.5 KiB
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
# file Copyright.txt or https://cmake.org/licensing for details.
|
|
|
|
#[=======================================================================[.rst:
|
|
FindVulkan
|
|
----------
|
|
|
|
.. versionadded:: 3.7
|
|
|
|
Find Vulkan, which is a low-overhead, cross-platform 3D graphics
|
|
and computing API.
|
|
|
|
IMPORTED Targets
|
|
^^^^^^^^^^^^^^^^
|
|
|
|
This module defines :prop_tgt:`IMPORTED` targets if Vulkan has been found:
|
|
|
|
``Vulkan::Vulkan``
|
|
The main Vulkan library.
|
|
|
|
``Vulkan::glslc``
|
|
.. versionadded:: 3.19
|
|
|
|
The GLSLC SPIR-V compiler, if it has been found.
|
|
|
|
``Vulkan::Headers``
|
|
.. versionadded:: 3.21
|
|
|
|
Provides just Vulkan headers include paths, if found. No library is
|
|
included in this target. This can be useful for applications that
|
|
load Vulkan library dynamically.
|
|
|
|
``Vulkan::glslangValidator``
|
|
.. versionadded:: 3.21
|
|
|
|
The glslangValidator tool, if found. It is used to compile GLSL and
|
|
HLSL shaders into SPIR-V.
|
|
|
|
Result Variables
|
|
^^^^^^^^^^^^^^^^
|
|
|
|
This module defines the following variables:
|
|
|
|
``Vulkan_FOUND``
|
|
set to true if Vulkan was found
|
|
``Vulkan_INCLUDE_DIRS``
|
|
include directories for Vulkan
|
|
``Vulkan_LIBRARIES``
|
|
link against this library to use Vulkan
|
|
``Vulkan_VERSION``
|
|
.. versionadded:: 3.23
|
|
|
|
value from ``vulkan/vulkan_core.h``
|
|
|
|
The module will also defines these cache variables:
|
|
|
|
``Vulkan_INCLUDE_DIR``
|
|
the Vulkan include directory
|
|
``Vulkan_LIBRARY``
|
|
the path to the Vulkan library
|
|
``Vulkan_GLSLC_EXECUTABLE``
|
|
the path to the GLSL SPIR-V compiler
|
|
``Vulkan_GLSLANG_VALIDATOR_EXECUTABLE``
|
|
the path to the glslangValidator tool
|
|
|
|
Hints
|
|
^^^^^
|
|
|
|
.. versionadded:: 3.18
|
|
|
|
The ``VULKAN_SDK`` environment variable optionally specifies the
|
|
location of the Vulkan SDK root directory for the given
|
|
architecture. It is typically set by sourcing the toplevel
|
|
``setup-env.sh`` script of the Vulkan SDK directory into the shell
|
|
environment.
|
|
|
|
#]=======================================================================]
|
|
|
|
if(WIN32)
|
|
find_path(Vulkan_INCLUDE_DIR
|
|
NAMES vulkan/vulkan.h
|
|
HINTS
|
|
"$ENV{VULKAN_SDK}/Include"
|
|
)
|
|
|
|
if(CMAKE_SIZEOF_VOID_P EQUAL 8)
|
|
find_library(Vulkan_LIBRARY
|
|
NAMES vulkan-1
|
|
HINTS
|
|
"$ENV{VULKAN_SDK}/Lib"
|
|
"$ENV{VULKAN_SDK}/Bin"
|
|
)
|
|
find_program(Vulkan_GLSLC_EXECUTABLE
|
|
NAMES glslc
|
|
HINTS
|
|
"$ENV{VULKAN_SDK}/Bin"
|
|
)
|
|
find_program(Vulkan_GLSLANG_VALIDATOR_EXECUTABLE
|
|
NAMES glslangValidator
|
|
HINTS
|
|
"$ENV{VULKAN_SDK}/Bin"
|
|
)
|
|
elseif(CMAKE_SIZEOF_VOID_P EQUAL 4)
|
|
find_library(Vulkan_LIBRARY
|
|
NAMES vulkan-1
|
|
HINTS
|
|
"$ENV{VULKAN_SDK}/Lib32"
|
|
"$ENV{VULKAN_SDK}/Bin32"
|
|
)
|
|
find_program(Vulkan_GLSLC_EXECUTABLE
|
|
NAMES glslc
|
|
HINTS
|
|
"$ENV{VULKAN_SDK}/Bin32"
|
|
)
|
|
find_program(Vulkan_GLSLANG_VALIDATOR_EXECUTABLE
|
|
NAMES glslangValidator
|
|
HINTS
|
|
"$ENV{VULKAN_SDK}/Bin32"
|
|
)
|
|
endif()
|
|
else()
|
|
find_path(Vulkan_INCLUDE_DIR
|
|
NAMES vulkan/vulkan.h
|
|
HINTS "$ENV{VULKAN_SDK}/include")
|
|
find_library(Vulkan_LIBRARY
|
|
NAMES vulkan
|
|
HINTS "$ENV{VULKAN_SDK}/lib")
|
|
find_program(Vulkan_GLSLC_EXECUTABLE
|
|
NAMES glslc
|
|
HINTS "$ENV{VULKAN_SDK}/bin")
|
|
find_program(Vulkan_GLSLANG_VALIDATOR_EXECUTABLE
|
|
NAMES glslangValidator
|
|
HINTS "$ENV{VULKAN_SDK}/bin")
|
|
endif()
|
|
|
|
set(Vulkan_LIBRARIES ${Vulkan_LIBRARY})
|
|
set(Vulkan_INCLUDE_DIRS ${Vulkan_INCLUDE_DIR})
|
|
|
|
# detect version e.g 1.2.189
|
|
set(Vulkan_VERSION "")
|
|
if(Vulkan_INCLUDE_DIR)
|
|
set(VULKAN_CORE_H ${Vulkan_INCLUDE_DIR}/vulkan/vulkan_core.h)
|
|
if(EXISTS ${VULKAN_CORE_H})
|
|
file(STRINGS ${VULKAN_CORE_H} VulkanHeaderVersionLine REGEX "^#define VK_HEADER_VERSION ")
|
|
string(REGEX MATCHALL "[0-9]+" VulkanHeaderVersion "${VulkanHeaderVersionLine}")
|
|
file(STRINGS ${VULKAN_CORE_H} VulkanHeaderVersionLine2 REGEX "^#define VK_HEADER_VERSION_COMPLETE ")
|
|
string(REGEX MATCHALL "[0-9]+" VulkanHeaderVersion2 "${VulkanHeaderVersionLine2}")
|
|
list(LENGTH VulkanHeaderVersion2 _len)
|
|
# versions >= 1.2.175 have an additional numbers in front of e.g. '0, 1, 2' instead of '1, 2'
|
|
if(_len EQUAL 3)
|
|
list(REMOVE_AT VulkanHeaderVersion2 0)
|
|
endif()
|
|
list(APPEND VulkanHeaderVersion2 ${VulkanHeaderVersion})
|
|
list(JOIN VulkanHeaderVersion2 "." Vulkan_VERSION)
|
|
endif()
|
|
endif()
|
|
|
|
include(${CMAKE_CURRENT_LIST_DIR}/FindPackageHandleStandardArgs.cmake)
|
|
find_package_handle_standard_args(Vulkan
|
|
REQUIRED_VARS
|
|
Vulkan_LIBRARY
|
|
Vulkan_INCLUDE_DIR
|
|
VERSION_VAR
|
|
Vulkan_VERSION
|
|
)
|
|
|
|
mark_as_advanced(Vulkan_INCLUDE_DIR Vulkan_LIBRARY Vulkan_GLSLC_EXECUTABLE
|
|
Vulkan_GLSLANG_VALIDATOR_EXECUTABLE)
|
|
|
|
if(Vulkan_FOUND AND NOT TARGET Vulkan::Vulkan)
|
|
add_library(Vulkan::Vulkan UNKNOWN IMPORTED)
|
|
set_target_properties(Vulkan::Vulkan PROPERTIES
|
|
IMPORTED_LOCATION "${Vulkan_LIBRARIES}"
|
|
INTERFACE_INCLUDE_DIRECTORIES "${Vulkan_INCLUDE_DIRS}")
|
|
endif()
|
|
|
|
if(Vulkan_FOUND AND NOT TARGET Vulkan::Headers)
|
|
add_library(Vulkan::Headers INTERFACE IMPORTED)
|
|
set_target_properties(Vulkan::Headers PROPERTIES
|
|
INTERFACE_INCLUDE_DIRECTORIES "${Vulkan_INCLUDE_DIRS}")
|
|
endif()
|
|
|
|
if(Vulkan_FOUND AND Vulkan_GLSLC_EXECUTABLE AND NOT TARGET Vulkan::glslc)
|
|
add_executable(Vulkan::glslc IMPORTED)
|
|
set_property(TARGET Vulkan::glslc PROPERTY IMPORTED_LOCATION "${Vulkan_GLSLC_EXECUTABLE}")
|
|
endif()
|
|
|
|
if(Vulkan_FOUND AND Vulkan_GLSLANG_VALIDATOR_EXECUTABLE AND NOT TARGET Vulkan::glslangValidator)
|
|
add_executable(Vulkan::glslangValidator IMPORTED)
|
|
set_property(TARGET Vulkan::glslangValidator PROPERTY IMPORTED_LOCATION "${Vulkan_GLSLANG_VALIDATOR_EXECUTABLE}")
|
|
endif()
|