mirror of
https://gitee.com/openharmony/third_party_vulkan-headers
synced 2024-11-23 07:49:47 +00:00
vulkan-headers upgrade to sdk-1.3.250.1
Signed-off-by: shegangbin <shegangbin1@huawei.com>
This commit is contained in:
parent
6c63f3cc75
commit
cd7285a5fb
@ -1,34 +0,0 @@
|
|||||||
# Configuration for cmake-format (v0.4.1, circa Jul 2018)
|
|
||||||
# https://github.com/cheshirekow/cmake_format
|
|
||||||
|
|
||||||
# How wide to allow formatted cmake files
|
|
||||||
line_width = 132
|
|
||||||
|
|
||||||
# How many spaces to tab for indent
|
|
||||||
tab_size = 4
|
|
||||||
|
|
||||||
# If arglists are longer than this, break them always
|
|
||||||
max_subargs_per_line = 3
|
|
||||||
|
|
||||||
# If true, separate flow control names from their parentheses with a space
|
|
||||||
separate_ctrl_name_with_space = False
|
|
||||||
|
|
||||||
# If true, separate function names from parentheses with a space
|
|
||||||
separate_fn_name_with_space = False
|
|
||||||
|
|
||||||
# If a statement is wrapped to more than one line, than dangle the closing
|
|
||||||
# parenthesis on it's own line
|
|
||||||
dangle_parens = False
|
|
||||||
|
|
||||||
# What character to use for bulleted lists
|
|
||||||
bullet_char = u'*'
|
|
||||||
|
|
||||||
# What character to use as punctuation after numerals in an enumerated list
|
|
||||||
enum_char = u'.'
|
|
||||||
|
|
||||||
# What style line endings to use in the output.
|
|
||||||
line_ending = u'unix'
|
|
||||||
|
|
||||||
# Format command names consistently as 'lower' or 'upper' case
|
|
||||||
command_case = u'lower'
|
|
||||||
|
|
15
BUILD.gn
15
BUILD.gn
@ -1,5 +1,5 @@
|
|||||||
# Copyright (C) 2018-2019 The ANGLE Project Authors.
|
# Copyright (C) 2018-2023 The ANGLE Project Authors.
|
||||||
# Copyright (C) 2019 LunarG, Inc.
|
# Copyright (C) 2019-2023 LunarG, Inc.
|
||||||
#
|
#
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
# you may not use this file except in compliance with the License.
|
# you may not use this file except in compliance with the License.
|
||||||
@ -56,15 +56,24 @@ config("vulkan_headers_config") {
|
|||||||
if (defined(is_ggp) && is_ggp) {
|
if (defined(is_ggp) && is_ggp) {
|
||||||
defines += [ "VK_USE_PLATFORM_GGP" ]
|
defines += [ "VK_USE_PLATFORM_GGP" ]
|
||||||
}
|
}
|
||||||
|
if (is_clang) {
|
||||||
|
cflags = [ "-Wno-redundant-parens" ]
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# Vulkan headers only, no compiled sources.
|
# Vulkan headers only, no compiled sources.
|
||||||
source_set("vulkan_headers") {
|
source_set("vulkan_headers") {
|
||||||
sources = [
|
sources = [
|
||||||
|
"include/vk_video/vulkan_video_codec_h264std.h",
|
||||||
|
"include/vk_video/vulkan_video_codec_h264std_decode.h",
|
||||||
|
"include/vk_video/vulkan_video_codec_h264std_encode.h",
|
||||||
|
"include/vk_video/vulkan_video_codec_h265std.h",
|
||||||
|
"include/vk_video/vulkan_video_codec_h265std_decode.h",
|
||||||
|
"include/vk_video/vulkan_video_codec_h265std_encode.h",
|
||||||
|
"include/vk_video/vulkan_video_codecs_common.h",
|
||||||
"include/vulkan/vk_icd.h",
|
"include/vulkan/vk_icd.h",
|
||||||
"include/vulkan/vk_layer.h",
|
"include/vulkan/vk_layer.h",
|
||||||
"include/vulkan/vk_platform.h",
|
"include/vulkan/vk_platform.h",
|
||||||
"include/vulkan/vk_sdk_platform.h",
|
|
||||||
"include/vulkan/vulkan.h",
|
"include/vulkan/vulkan.h",
|
||||||
"include/vulkan/vulkan.hpp",
|
"include/vulkan/vulkan.hpp",
|
||||||
"include/vulkan/vulkan_core.h",
|
"include/vulkan/vulkan_core.h",
|
||||||
|
274
BUILD.md
274
BUILD.md
@ -1,274 +1,42 @@
|
|||||||
# Build Instructions
|
# Build Instructions
|
||||||
|
|
||||||
Instructions for building this repository on Windows, Linux, and MacOS.
|
Instructions for building this repository.
|
||||||
|
|
||||||
## Index
|
```bash
|
||||||
|
git clone https://github.com/KhronosGroup/Vulkan-Headers.git
|
||||||
|
|
||||||
1. [Contributing](#contributing-to-the-repository)
|
cd Vulkan-Headers/
|
||||||
1. [Repository Content](#repository-content)
|
|
||||||
1. [Repository Set-up](#repository-set-up)
|
|
||||||
1. [Windows Build](#building-on-windows)
|
|
||||||
1. [Linux Build](#building-on-linux)
|
|
||||||
1. [MacOS Build](#building-on-macos)
|
|
||||||
|
|
||||||
## Contributing to the Repository
|
# Configure the project
|
||||||
|
cmake -S . -B build/
|
||||||
|
|
||||||
The contents of this repository are sourced primarily from the Khronos Vulkan
|
# Because Vulkan-Headers is header only we don't need to build anything.
|
||||||
API specification [repository](https://github.com/KhronosGroup/Vulkan-Docs).
|
# Users can install it where they need to.
|
||||||
Please visit that repository for information on contributing.
|
cmake --install build --prefix build/install
|
||||||
|
```
|
||||||
|
|
||||||
## Repository Content
|
See the official [CMake documentation](https://cmake.org/cmake/help/latest/index.html) for more information.
|
||||||
|
|
||||||
This repository contains the Vulkan header files and the Vulkan API definition
|
## Installed Files
|
||||||
(registry) with its related files. This repository does not create libraries
|
|
||||||
or executables.
|
|
||||||
|
|
||||||
However, this repository contains CMake build configuration files to "install"
|
|
||||||
the files from this repository to a specific install directory. For example,
|
|
||||||
you can install the files to a system directory such as `/usr/local` on Linux.
|
|
||||||
|
|
||||||
If you are building other Vulkan-related repositories such as
|
|
||||||
[Vulkan-Loader](https://github.com/KhronosGroup/Vulkan-Loader),
|
|
||||||
you need to build the install target of this repository and provide the
|
|
||||||
resulting install directory to those repositories.
|
|
||||||
|
|
||||||
### Installed Files
|
|
||||||
|
|
||||||
The `install` target installs the following files under the directory
|
The `install` target installs the following files under the directory
|
||||||
indicated by *install_dir*:
|
indicated by *install_dir*:
|
||||||
|
|
||||||
- *install_dir*`/include/vulkan` : The header files found in the
|
- *install_dir*`/include/vulkan` : The header files found in the
|
||||||
`include/vulkan` directory of this repository
|
`include/vulkan` directory of this repository
|
||||||
|
- *install_dir*`/share/cmake/VulkanHeaders`: The CMake config files needed
|
||||||
|
for find_package support
|
||||||
- *install_dir*`/share/vulkan/registry` : The registry files found in the
|
- *install_dir*`/share/vulkan/registry` : The registry files found in the
|
||||||
`registry` directory of this repository
|
`registry` directory of this repository
|
||||||
|
|
||||||
The `uninstall` target can be used to remove the above files from the install
|
## Usage in CMake
|
||||||
directory.
|
|
||||||
|
|
||||||
## Repository Set-Up
|
```cmake
|
||||||
|
find_package(VulkanHeaders REQUIRED CONFIG)
|
||||||
|
|
||||||
### Download the Repository
|
target_link_libraries(foobar PRIVATE Vulkan::Headers)
|
||||||
|
|
||||||
To create your local git repository:
|
message(STATUS "Vulkan Headers Registry: ${VULKAN_HEADERS_REGISTRY_DIRECTORY}")
|
||||||
|
|
||||||
git clone https://github.com/KhronosGroup/Vulkan-Headers.git
|
message(STATUS "Vulkan Headers Version: ${VulkanHeaders_VERSION}")
|
||||||
|
```
|
||||||
### Repository Dependencies
|
|
||||||
|
|
||||||
This repository does not depend on any other repositories.
|
|
||||||
|
|
||||||
### Build and Install Directories
|
|
||||||
|
|
||||||
A common convention is to place the build directory in the top directory of
|
|
||||||
the repository with a name of `build` and place the install directory as a
|
|
||||||
child of the build directory with the name `install`. The remainder of these
|
|
||||||
instructions follow this convention, although you can use any name for these
|
|
||||||
directories and place them in any location.
|
|
||||||
|
|
||||||
## Building On Windows
|
|
||||||
|
|
||||||
### Windows Development Environment Requirements
|
|
||||||
|
|
||||||
- Windows
|
|
||||||
- Any Personal Computer version supported by Microsoft
|
|
||||||
- Microsoft [Visual Studio](https://www.visualstudio.com/)
|
|
||||||
- Versions
|
|
||||||
- [2015](https://www.visualstudio.com/vs/older-downloads/)
|
|
||||||
- [2017](https://www.visualstudio.com/vs/older-downloads/)
|
|
||||||
- [2019](https://www.visualstudio.com/vs/downloads/)
|
|
||||||
- The Community Edition of each of the above versions is sufficient, as
|
|
||||||
well as any more capable edition.
|
|
||||||
- [CMake 3.10.2](https://cmake.org/files/v3.10/cmake-3.10.2-win64-x64.zip) is recommended.
|
|
||||||
- Use the installer option to add CMake to the system PATH
|
|
||||||
- Git Client Support
|
|
||||||
- [Git for Windows](http://git-scm.com/download/win) is a popular solution
|
|
||||||
for Windows
|
|
||||||
- Some IDEs (e.g., [Visual Studio](https://www.visualstudio.com/),
|
|
||||||
[GitHub Desktop](https://desktop.github.com/)) have integrated
|
|
||||||
Git client support
|
|
||||||
|
|
||||||
### Windows Build - Microsoft Visual Studio
|
|
||||||
|
|
||||||
The general approach is to run CMake to generate the Visual Studio project
|
|
||||||
files. Then either run CMake with the `--build` option to build from the
|
|
||||||
command line or use the Visual Studio IDE to open the generated solution and
|
|
||||||
work with the solution interactively.
|
|
||||||
|
|
||||||
#### Windows Quick Start
|
|
||||||
|
|
||||||
From a "Developer Command Prompt for VS 201x" console:
|
|
||||||
|
|
||||||
cd Vulkan-Headers
|
|
||||||
mkdir build
|
|
||||||
cd build
|
|
||||||
cmake ..
|
|
||||||
cmake --build . --target install
|
|
||||||
|
|
||||||
See below for the details.
|
|
||||||
|
|
||||||
#### Use `CMake` to Create the Visual Studio Project Files
|
|
||||||
|
|
||||||
From within a "Developer Command Prompt for VS 201x" console, change your
|
|
||||||
current directory to the top of the cloned repository directory, create a
|
|
||||||
build directory and generate the Visual Studio project files:
|
|
||||||
|
|
||||||
cd Vulkan-Headers
|
|
||||||
mkdir build
|
|
||||||
cd build
|
|
||||||
cmake ..
|
|
||||||
|
|
||||||
> Note: The `..` parameter tells `cmake` the location of the top of the
|
|
||||||
> repository. If you place your build directory someplace else, you'll need to
|
|
||||||
> specify the location of the repository top differently.
|
|
||||||
|
|
||||||
The CMake configuration files set the default install directory location to
|
|
||||||
`$CMAKE_BINARY_DIR\install`, which is a child of your build directory. In this
|
|
||||||
example, the install directory becomes the `Vulkan-Headers\build\install`
|
|
||||||
directory.
|
|
||||||
|
|
||||||
The project installs the header files to
|
|
||||||
|
|
||||||
Vulkan-Headers\build\install\include\vulkan
|
|
||||||
|
|
||||||
and installs the registry files to
|
|
||||||
|
|
||||||
Vulkan-Headers\build\install\share\vulkan\registry
|
|
||||||
|
|
||||||
You can change the install directory with the `CMAKE_INSTALL_PREFIX` CMake
|
|
||||||
variable.
|
|
||||||
|
|
||||||
For example:
|
|
||||||
|
|
||||||
cd Vulkan-Headers
|
|
||||||
mkdir build
|
|
||||||
cd build
|
|
||||||
cmake -DCMAKE_INSTALL_PREFIX=/c/Users/dev/install .. # MINGW64 shell
|
|
||||||
|
|
||||||
As it starts generating the project files, `cmake` responds with something
|
|
||||||
like:
|
|
||||||
|
|
||||||
-- Building for: Visual Studio 14 2015
|
|
||||||
|
|
||||||
which is a 32-bit generator.
|
|
||||||
|
|
||||||
Since this repository does not compile anything, there is no need to specify a
|
|
||||||
specific generator such as "Visual Studio 14 2015 Win64", so the default
|
|
||||||
generator should suffice.
|
|
||||||
|
|
||||||
The above steps create a Windows solution file named `Vulkan-Headers.sln` in
|
|
||||||
the build directory.
|
|
||||||
|
|
||||||
At this point, you can build the solution from the command line or open the
|
|
||||||
generated solution with Visual Studio.
|
|
||||||
|
|
||||||
#### Build the Solution From the Command Line
|
|
||||||
|
|
||||||
While still in the build directory:
|
|
||||||
|
|
||||||
cmake --build . --target install
|
|
||||||
|
|
||||||
to build the install target.
|
|
||||||
|
|
||||||
Build the `uninstall` target to remove the files from the install directory.
|
|
||||||
|
|
||||||
cmake --build . --target uninstall
|
|
||||||
|
|
||||||
#### Build the Solution With Visual Studio
|
|
||||||
|
|
||||||
Launch Visual Studio and open the "Vulkan-Headers.sln" solution file in the
|
|
||||||
build directory. Build the `INSTALL` target from the Visual Studio solution
|
|
||||||
explorer.
|
|
||||||
|
|
||||||
Build the `uninstall` target to remove the files from the install directory.
|
|
||||||
|
|
||||||
> Note: Since there are only the `INSTALL` and `uninstall` projects in the
|
|
||||||
> solution, building the solution from the command line may be more efficient
|
|
||||||
> than starting Visual Studio for these simple operations.
|
|
||||||
|
|
||||||
## Building On Linux
|
|
||||||
|
|
||||||
### Linux Development Environment Requirements
|
|
||||||
|
|
||||||
There are no specific Linux distribution or compiler version requirements for
|
|
||||||
building this repository. The required tools are
|
|
||||||
|
|
||||||
- [CMake 3.10.2](https://cmake.org/files/v3.10/cmake-3.10.2-Linux-x86_64.tar.gz) is recommended.
|
|
||||||
- git
|
|
||||||
|
|
||||||
### Linux Build
|
|
||||||
|
|
||||||
The general approach is to run CMake to generate make files. Then either run
|
|
||||||
CMake with the `--build` option or `make` to build from the command line.
|
|
||||||
|
|
||||||
#### Linux Quick Start
|
|
||||||
|
|
||||||
cd Vulkan-Headers
|
|
||||||
mkdir build
|
|
||||||
cd build
|
|
||||||
cmake -DCMAKE_INSTALL_PREFIX=install ..
|
|
||||||
make install
|
|
||||||
|
|
||||||
See below for the details.
|
|
||||||
|
|
||||||
#### Use CMake to Create the Make Files
|
|
||||||
|
|
||||||
Change your current directory to the top of the cloned repository directory,
|
|
||||||
create a build directory and generate the make files:
|
|
||||||
|
|
||||||
cd Vulkan-Headers
|
|
||||||
mkdir build
|
|
||||||
cd build
|
|
||||||
cmake -DCMAKE_INSTALL_PREFIX=install ..
|
|
||||||
|
|
||||||
> Note: The `..` parameter tells `cmake` the location of the top of the
|
|
||||||
> repository. If you place your `build` directory someplace else, you'll need
|
|
||||||
> to specify the location of the repository top differently.
|
|
||||||
|
|
||||||
Set the `CMAKE_INSTALL_PREFIX` variable to the directory to serve as the
|
|
||||||
destination directory for the `install` target.
|
|
||||||
|
|
||||||
The above `cmake` command sets the install directory to
|
|
||||||
`$CMAKE_BINARY_DIR/install`, which is a child of your `build` directory. In
|
|
||||||
this example, the install directory becomes the `Vulkan-Headers/build/install`
|
|
||||||
directory.
|
|
||||||
|
|
||||||
The make file install target installs the header files to
|
|
||||||
|
|
||||||
Vulkan-Headers/build/install/include/vulkan
|
|
||||||
|
|
||||||
and installs the registry files to
|
|
||||||
|
|
||||||
Vulkan-Headers/build/install/share/vulkan/registry
|
|
||||||
|
|
||||||
> Note: For Linux, the default value for `CMAKE_INSTALL_PREFIX` is
|
|
||||||
> `/usr/local`, which would be used if you do not specify
|
|
||||||
> `CMAKE_INSTALL_PREFIX`. In this case, you may need to use `sudo` to install
|
|
||||||
> to system directories later when you run `make install`.
|
|
||||||
|
|
||||||
Note that after generating the make files, running `make`:
|
|
||||||
|
|
||||||
make
|
|
||||||
|
|
||||||
does nothing, since there are no libraries or executables to build.
|
|
||||||
|
|
||||||
To install the header files:
|
|
||||||
|
|
||||||
make install
|
|
||||||
|
|
||||||
or
|
|
||||||
|
|
||||||
cmake --build . --target install
|
|
||||||
|
|
||||||
To uninstall the files from the install directories, you can execute:
|
|
||||||
|
|
||||||
make uninstall
|
|
||||||
|
|
||||||
or
|
|
||||||
|
|
||||||
cmake --build . --target uninstall
|
|
||||||
|
|
||||||
## Building on MacOS
|
|
||||||
|
|
||||||
The instructions for building this repository on MacOS are similar to those for Linux.
|
|
||||||
|
|
||||||
[CMake 3.10.2](https://cmake.org/files/v3.10/cmake-3.10.2-Darwin-x86_64.tar.gz) is recommended.
|
|
||||||
|
103
CMakeLists.txt
103
CMakeLists.txt
@ -1,6 +1,6 @@
|
|||||||
# ~~~
|
# ~~~
|
||||||
# Copyright (c) 2018 Valve Corporation
|
# Copyright (c) 2018-2023 Valve Corporation
|
||||||
# Copyright (c) 2018 LunarG, Inc.
|
# Copyright (c) 2018-2023 LunarG, Inc.
|
||||||
#
|
#
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
# you may not use this file except in compliance with the License.
|
# you may not use this file except in compliance with the License.
|
||||||
@ -14,46 +14,81 @@
|
|||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
# ~~~
|
# ~~~
|
||||||
|
cmake_minimum_required(VERSION 3.15...3.25)
|
||||||
|
|
||||||
# CMake project initialization ---------------------------------------------------------------------------------------------------
|
function(vlk_get_header_version)
|
||||||
# This section contains pre-project() initialization, and ends with the project() command.
|
set(vulkan_core_header_file "${CMAKE_CURRENT_SOURCE_DIR}/include/vulkan/vulkan_core.h")
|
||||||
|
if (NOT EXISTS ${vulkan_core_header_file})
|
||||||
|
message(FATAL_ERROR "Couldn't find vulkan_core.h!")
|
||||||
|
endif()
|
||||||
|
|
||||||
cmake_minimum_required(VERSION 3.10.2)
|
file(READ ${vulkan_core_header_file} ver)
|
||||||
|
|
||||||
# NONE = this project has no language toolchain requirement.
|
if (ver MATCHES "#define[ ]+VK_HEADER_VERSION_COMPLETE[ ]+VK_MAKE_API_VERSION\\([ ]*[0-9]+,[ ]*([0-9]+),[ ]*([0-9]+),[ ]*VK_HEADER_VERSION[ ]*\\)")
|
||||||
project(Vulkan-Headers NONE)
|
set(MAJOR_VERSION "${CMAKE_MATCH_1}")
|
||||||
|
set(MINOR_VERSION "${CMAKE_MATCH_2}")
|
||||||
|
else()
|
||||||
|
message(FATAL_ERROR "Couldn't get major/minor version")
|
||||||
|
endif()
|
||||||
|
|
||||||
# User-interface declarations ----------------------------------------------------------------------------------------------------
|
if (ver MATCHES "#define[ ]+VK_HEADER_VERSION[ ]+([0-9]+)")
|
||||||
# This section contains variables that affect development GUIs (e.g. CMake GUI and IDEs), such as option(), folders, and variables
|
set(PATCH_VERSION "${CMAKE_MATCH_1}")
|
||||||
# with the CACHE property.
|
else()
|
||||||
|
message(FATAL_ERROR "Couldn't get the patch version")
|
||||||
|
endif()
|
||||||
|
|
||||||
include(GNUInstallDirs)
|
set(VK_VERSION_STRING "${MAJOR_VERSION}.${MINOR_VERSION}.${PATCH_VERSION}" PARENT_SCOPE)
|
||||||
|
endfunction()
|
||||||
|
vlk_get_header_version()
|
||||||
|
|
||||||
if(WIN32 AND CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT)
|
project(VULKAN_HEADERS LANGUAGES C VERSION ${VK_VERSION_STRING})
|
||||||
# Windows: if install locations not set by user, set install prefix to "<build_dir>\install".
|
|
||||||
set(CMAKE_INSTALL_PREFIX "${CMAKE_BINARY_DIR}/install" CACHE PATH "default install path" FORCE)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# --------------------------------------------------------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# define exported targets for nested project builds to consume
|
|
||||||
add_library(Vulkan-Headers INTERFACE)
|
add_library(Vulkan-Headers INTERFACE)
|
||||||
target_include_directories(Vulkan-Headers INTERFACE "${CMAKE_CURRENT_SOURCE_DIR}/include")
|
|
||||||
add_library(Vulkan::Headers ALIAS Vulkan-Headers)
|
add_library(Vulkan::Headers ALIAS Vulkan-Headers)
|
||||||
|
target_include_directories(Vulkan-Headers INTERFACE $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>)
|
||||||
|
|
||||||
add_library(Vulkan-Registry INTERFACE)
|
if (CMAKE_VERSION VERSION_LESS "3.21")
|
||||||
target_include_directories(Vulkan-Registry INTERFACE "${CMAKE_CURRENT_SOURCE_DIR}/registry")
|
# https://cmake.org/cmake/help/latest/variable/PROJECT_IS_TOP_LEVEL.html
|
||||||
add_library(Vulkan::Registry ALIAS Vulkan-Registry)
|
string(COMPARE EQUAL ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_SOURCE_DIR} PROJECT_IS_TOP_LEVEL)
|
||||||
|
endif()
|
||||||
install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/include/vulkan" DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
|
|
||||||
install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/include/vk_video" DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
|
if (PROJECT_IS_TOP_LEVEL)
|
||||||
install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/registry" DESTINATION ${CMAKE_INSTALL_DATADIR}/vulkan)
|
option(BUILD_TESTS "Build the tests")
|
||||||
|
if (BUILD_TESTS)
|
||||||
# uninstall target
|
add_subdirectory(tests)
|
||||||
if(NOT TARGET uninstall)
|
endif()
|
||||||
configure_file("${CMAKE_CURRENT_SOURCE_DIR}/cmake/cmake_uninstall.cmake.in"
|
|
||||||
"${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake"
|
include(GNUInstallDirs)
|
||||||
IMMEDIATE
|
include(CMakePackageConfigHelpers)
|
||||||
@ONLY)
|
|
||||||
add_custom_target(uninstall COMMAND ${CMAKE_COMMAND} -P ${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake)
|
set(VLK_REGISTRY_DIR "${CMAKE_INSTALL_DATADIR}/vulkan")
|
||||||
|
|
||||||
|
install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/include/vk_video" DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
|
||||||
|
install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/include/vulkan" DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
|
||||||
|
# Preserve source permissions https://github.com/KhronosGroup/Vulkan-Headers/issues/336
|
||||||
|
install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/registry" DESTINATION ${VLK_REGISTRY_DIR} USE_SOURCE_PERMISSIONS)
|
||||||
|
|
||||||
|
set(cmake_files_install_dir ${CMAKE_INSTALL_DATADIR}/cmake/VulkanHeaders/)
|
||||||
|
|
||||||
|
set_target_properties(Vulkan-Headers PROPERTIES EXPORT_NAME "Headers")
|
||||||
|
|
||||||
|
install(TARGETS Vulkan-Headers EXPORT VulkanHeadersTargets INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
|
||||||
|
|
||||||
|
install(EXPORT VulkanHeadersTargets FILE VulkanHeadersTargets.cmake NAMESPACE "Vulkan::" DESTINATION ${cmake_files_install_dir})
|
||||||
|
|
||||||
|
set(vulkan_headers_config "${CMAKE_CURRENT_BINARY_DIR}/VulkanHeadersConfig.cmake")
|
||||||
|
set(VULKAN_HEADERS_REGISTRY_DIRECTORY "${VLK_REGISTRY_DIR}/registry")
|
||||||
|
|
||||||
|
configure_package_config_file(${CMAKE_CURRENT_SOURCE_DIR}/cmake/VulkanHeadersConfig.cmake.in ${vulkan_headers_config}
|
||||||
|
INSTALL_DESTINATION ${cmake_files_install_dir}
|
||||||
|
PATH_VARS VULKAN_HEADERS_REGISTRY_DIRECTORY
|
||||||
|
NO_SET_AND_CHECK_MACRO
|
||||||
|
NO_CHECK_REQUIRED_COMPONENTS_MACRO
|
||||||
|
)
|
||||||
|
|
||||||
|
set(config_version "${CMAKE_CURRENT_BINARY_DIR}/VulkanHeadersConfigVersion.cmake")
|
||||||
|
|
||||||
|
write_basic_package_version_file(${config_version} COMPATIBILITY SameMajorVersion ARCH_INDEPENDENT)
|
||||||
|
|
||||||
|
install(FILES ${config_version} ${vulkan_headers_config} DESTINATION ${cmake_files_install_dir})
|
||||||
endif()
|
endif()
|
||||||
|
35
CONTRIBUTING.md
Normal file
35
CONTRIBUTING.md
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
# CONTRIBUTING
|
||||||
|
|
||||||
|
Please note when contributing what files this repository actually is responsible for.
|
||||||
|
|
||||||
|
The majority for the Vulkan headers come from [Vulkan-Docs](https://github.com/KhronosGroup/Vulkan-Docs) or [Vulkan-Hpp](https://github.com/KhronosGroup/Vulkan-Hpp)
|
||||||
|
|
||||||
|
### This repository (https://github.com/KhronosGroup/Vulkan-Headers)
|
||||||
|
|
||||||
|
* BUILD.gn
|
||||||
|
* BUILD.md
|
||||||
|
* cmake/
|
||||||
|
* CMakeLists.txt
|
||||||
|
* tests/*
|
||||||
|
* CODE_OF_CONDUCT.md
|
||||||
|
* INTEGRATION.md
|
||||||
|
* LICENSE.txt
|
||||||
|
* README.md
|
||||||
|
* Non-API headers
|
||||||
|
* include/vulkan/vk_icd.h
|
||||||
|
* include/vulkan/vk_layer.h
|
||||||
|
|
||||||
|
### Specification repository (https://github.com/KhronosGroup/Vulkan-Docs)
|
||||||
|
|
||||||
|
* registry/*.py
|
||||||
|
* registry/spec_tools/*.py
|
||||||
|
* registry/profiles/*.json
|
||||||
|
* All files under include/vulkan/ which are *not* listed explicitly as originating from another repository.
|
||||||
|
|
||||||
|
### Vulkan C++ Binding Repository (https://github.com/KhronosGroup/Vulkan-Hpp)
|
||||||
|
|
||||||
|
As of the Vulkan-Docs 1.2.182 spec update, the Vulkan-Hpp headers have been
|
||||||
|
split into multiple files. All of those files are now included in this
|
||||||
|
repository.
|
||||||
|
|
||||||
|
* include/vulkan/*.hpp
|
99
INTEGRATION.md
Normal file
99
INTEGRATION.md
Normal file
@ -0,0 +1,99 @@
|
|||||||
|
# Integrating Updated Vulkan Headers into Vulkan Repositories
|
||||||
|
|
||||||
|
- This guide assumes the [Vulkan-Headers](https://github.com/KhronosGroup/Vulkan-Headers), [Vulkan-Loader](https://github.com/KhronosGroup/Vulkan-Loader), [Vulkan-Tools](https://github.com/KhronosGroup/Vulkan-Tools), [Vulkan-ValidationLayers](https://github.com/KhronosGroup/Vulkan-ValidationLayers), [LunarG/VulkanSamples](https://github.com/LunarG/VulkanSamples), and [LunarG/VulkanTools](https://github.com/LunarG/VulkanTools) repositories have been cloned to a known directory on the system. If necessary, see the `BUILD.md` file in each repository for information on how to clone and build the projects.
|
||||||
|
- If build issues exist at any point in the Vulkan header integration process, include the fix in the known-good update commit, propose a fix by creating a pull request, or create an issue in the relevant repository and wait for resolution.
|
||||||
|
|
||||||
|
# Clone and build the Vulkan-Headers
|
||||||
|
|
||||||
|
The first step of integrating Vulkan header updates is to checkout and build the desired Vulkan-Headers commit. Typically this is the latest tagged release.
|
||||||
|
|
||||||
|
Pull and build the dependent repositories
|
||||||
|
|
||||||
|
Update the Vulkan-Loader, Vulkan-ValidationLayers, and Vulkan-Tools known-good files
|
||||||
|
|
||||||
|
### Recommended order for updating the repositories
|
||||||
|
|
||||||
|
If the known-good of a repository needs to be updated, all repositories of interest that appear in its known-good files must be updated first using the procedure described in this wiki. See section [5. Update the Known Good Files](https://github.com/KhronosGroup/Vulkan-Headers/wiki/Integrating-Updated-Vulkan-Headers-into-Vulkan-Repositories/#5-update-the-known-good-files) for a list of dependencies per repository. The following list indicates the preferred known-good update order:
|
||||||
|
1. Vulkan-Loader
|
||||||
|
1. Vulkan-ValidationLayers
|
||||||
|
3. Vulkan-Tools
|
||||||
|
4. LunarG repositories when applicable
|
||||||
|
|
||||||
|
**Notes**:
|
||||||
|
* Typically the Vulkan-Loader's known-good is updated first, but the Vulkan-ValidationLayers known-good can also be updated first.
|
||||||
|
* The Vulkan-ValidationLayers GitHub CI currently contains a dependency on LunarG-VulkanTools. Occasionally Vulkan-Header updates require changes to be made to LunarG-VulkanTools before updating Vulkan-ValidationLayers known-good files (see the [update LunarG known-good section](https://github.com/KhronosGroup/Vulkan-Headers/wiki/Integrating-Vulkan-Header-Updates-into-Vulkan-Repositories#update-the-lunargvulkantools-and-lunargvulkansamples-known-good-files) below for more information).
|
||||||
|
|
||||||
|
### 1. Checkout and pull the `master` branch
|
||||||
|
|
||||||
|
Navigate to the directory of the project of interest and checkout the `master` branch. Pull in the most recent commits.
|
||||||
|
|
||||||
|
### 2. Generate new source files using `scripts/generate_source.py`
|
||||||
|
|
||||||
|
Using your favorite command prompt, navigate to the `scripts` directory and run the `generate_source.py` script. This script requires the specification of the location of the `Vulkan-Headers/registry` directory on the system. An example of how to run this script:
|
||||||
|
```
|
||||||
|
./generate_source.py ../../Vulkan-Headers/registry/
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 2-1. Propogate `genvk.py` changes
|
||||||
|
|
||||||
|
All Khronos repositories and LunarG/VulkanTools contain a flavor of Vulkan-Headers's `genvk.py`. If `genvk.py` in the Vulkan-Headers repository is modified, the same changes must be made to each version of the file in each repository as part of the header update.
|
||||||
|
|
||||||
|
#### 2-2. Vulkan-ValidationLayers sub-step: check for VUID inconsistencies
|
||||||
|
|
||||||
|
In Vulkan-ValidationLayers, every time the `generate_source.py` script is run a new VUID database is generated. When VUIDs are added, removed, or modified consistency testing must be performed. The `vk_validation_stats.py` script found in the ValidationLayers `scripts` directory can be used to report consistency warnings using the `-c` option.
|
||||||
|
```
|
||||||
|
./vk_validation_stats.py ../../Vulkan-Headers/registry/validusage.json -c
|
||||||
|
```
|
||||||
|
All consistency warnings must be resolved and included in the pull request for the repository's known-good update.
|
||||||
|
|
||||||
|
### 3. Build the project
|
||||||
|
|
||||||
|
Build the project, referring to the `BUILD.md` file in the directory if necessary.
|
||||||
|
|
||||||
|
### 4. Test the build
|
||||||
|
|
||||||
|
- To test the Vulkan-Loader build, run the loader tests (`run_all_tests.sh`) found in the `build/tests` directory. Information on how to build and run the tests can be found in the [Vulkan-Loader `BUILD.md`](https://github.com/KhronosGroup/Vulkan-Loader/blob/master/BUILD.md) file. **Note**: The `VK_LAYER_PATH` environment variable must be set to point at the layers found in `Vulkan-Loader/build/tests/layers` when running the loader tests.
|
||||||
|
|
||||||
|
- To test the Vulkan-ValidationLayers build, run the validation layers tests (`vk_layer_validation_tests`) found in the `build/tests` directory. Information on how to build and run the tests can be found in the [Vulkan-ValidationLayers `BUILD.md`](https://github.com/KhronosGroup/Vulkan-ValidationLayers/blob/master/BUILD.md) file.
|
||||||
|
|
||||||
|
- To test the Vulkan-Tools build, run `vkcube` and verify `vulkaninfo` produces reasonable output. More information on how to use `vulkaninfo` can be found [here](https://github.com/KhronosGroup/Vulkan-Tools/blob/master/vulkaninfo/vulkaninfo.md).
|
||||||
|
|
||||||
|
### 5. Update the known-good files
|
||||||
|
|
||||||
|
Every repository contains a `scripts/known_good.json` file which contains information about the known good commits for each dependent repository. Some repositories require an additional known-good file to be updated for Android builds and are specified below. Known-good updates require updating only the "commit" values of the relevant JSON objects. Using an existing tag for this value is preferred over using a full commit id. If a tag does not exist, typically the most recent commit on `master` is chosen for updating the known good. **Note**: Do not change commit values for repositories not listed below unless an update is absolutely required.
|
||||||
|
|
||||||
|
- Vulkan-Loader: Update requires specifying a new `Vulkan-Headers` commit in `scripts/known_good.json`
|
||||||
|
|
||||||
|
- Vulkan-ValidationLayers: Update requires specifying a new `Vulkan-Headers` commit in `scripts/known_good.json`. Additionally, new `Vulkan-Headers` and `Vulkan-Tools` commits must be specified in the `build-android/known_good.json` file.
|
||||||
|
|
||||||
|
- Vulkan-Tools: Update requires specifying new `Vulkan-Headers` and `Vulkan-Loader` commits in `scripts/known_good.json`. Additionally, a new `Vulkan-Headers` commit must be specified in the `vulkan-headers_revision_android` file.
|
||||||
|
|
||||||
|
### 6. Commit changes
|
||||||
|
|
||||||
|
Commit all changes (e.g., newly generated scripts, known-good files, etc.) in a single commit on a branch and push it up to the online repository. In Vulkan-ValidationLayers, VUID inconsistency resolutions can be included in a single commit with the known-good update or on the same branch in a separate commit.
|
||||||
|
|
||||||
|
### 7. Create a pull request in the relevant repository
|
||||||
|
|
||||||
|
Verify the branch with the proposed known-good commit is rebased on the tip of `master` and create a pull request in the GitHub repository. The repository owner will assign someone with push rights and specify reviewers for the PR. Prior to approval, the proposed changes will be run through internal LunarG CI testing.
|
||||||
|
|
||||||
|
### 8. Rebase changes onto `master`
|
||||||
|
|
||||||
|
Once the known-good update PR is approved, the assignee will rebase the approved commits onto the `master` branch.
|
||||||
|
|
||||||
|
### 9. Tag the known-good commit
|
||||||
|
|
||||||
|
Once approved and rebased onto `master`, the known-good update commit must be marked with a version tag. For more information on the version tag format see the "Version Tagging Scheme" section of each repository's `BUILD.md` file
|
||||||
|
|
||||||
|
## Update the LunarG/VulkanTools and LunarG/VulkanSamples known-good files
|
||||||
|
|
||||||
|
Updating the Known-good files in LunarG repositories follows the same steps as updating the known-good files in the Khronos repositories.
|
||||||
|
|
||||||
|
### Testing LunarG builds
|
||||||
|
|
||||||
|
- LunarG/VulkanTools: Build Debug and Release on Linux and Windows. Verify vktrace/replay works. Verify several of the layers built in this repo work.
|
||||||
|
- LunarG/VulkanSamples: Build all and run a few of the Vulkan Samples. Instructions on how to build and run the LunarG Vulkan samples can be found in the repository's [`BUILD.md` file](https://github.com/LunarG/VulkanSamples/blob/master/BUILD.md).
|
||||||
|
|
||||||
|
### Updating LunarG known-good files
|
||||||
|
|
||||||
|
- LunarG/VulkanTools: Update requires specifying new `Vulkan-Headers`, `Vulkan-Loader`, `Vulkan-Tools`, and `Vulkan-ValidationLayers` commits in `scripts/known_good.json`. Additionally, the new `Vulkan-Headers` commit must be specified in the `build-android/vulkan-headers_revision_android` file and the new `Vulkan-Tools` commit must be specified in the `build-android/vulkan-tools_revision_android` file.
|
||||||
|
- LunarG/VulkanSamples: Update requires specifying new `Vulkan-Headers` and `Vulkan-Loader` commits in `scripts/known_good.json`.
|
1
OAT.xml
1
OAT.xml
@ -65,6 +65,7 @@ Note: If the text contains special characters, please escape them according to t
|
|||||||
<policyitem type="copyright" name="Huawei Device Co., Ltd." path=".*" rule="may" group="defaultGroup" filefilter="copyrightPolicyFilter" desc=""/>
|
<policyitem type="copyright" name="Huawei Device Co., Ltd." path=".*" rule="may" group="defaultGroup" filefilter="copyrightPolicyFilter" desc=""/>
|
||||||
<policyitem type="copyright" name="Valve Corporation" path=".*" rule="may" group="defaultGroup" filefilter="copyrightPolicyFilter" desc=""/>
|
<policyitem type="copyright" name="Valve Corporation" path=".*" rule="may" group="defaultGroup" filefilter="copyrightPolicyFilter" desc=""/>
|
||||||
<policyitem type="copyright" name="Collabora, Ltd." path=".*" rule="may" group="defaultGroup" filefilter="copyrightPolicyFilter" desc=""/>
|
<policyitem type="copyright" name="Collabora, Ltd." path=".*" rule="may" group="defaultGroup" filefilter="copyrightPolicyFilter" desc=""/>
|
||||||
|
<policyitem type="copyright" name="*" path=".*" rule="may" group="defaultGroup" filefilter="copyrightPolicyFilter" desc=""/>
|
||||||
</policy>
|
</policy>
|
||||||
</policylist>
|
</policylist>
|
||||||
<filefilterlist>
|
<filefilterlist>
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
"Name": "Vulkan",
|
"Name": "Vulkan",
|
||||||
"License": "Apache-2.0",
|
"License": "Apache-2.0",
|
||||||
"License File": "LICENSE",
|
"License File": "LICENSE",
|
||||||
"Version Number": "v1.3.231",
|
"Version Number": "sdk-1.3.250.1",
|
||||||
"Owner": "mengzhaobing@huawei.com",
|
"Owner": "mengzhaobing@huawei.com",
|
||||||
"Upstream URL": "https://github.com/KhronosGroup/Vulkan-Headers.git",
|
"Upstream URL": "https://github.com/KhronosGroup/Vulkan-Headers.git",
|
||||||
"Description": "Vulkan header files and API registry"
|
"Description": "Vulkan header files and API registry"
|
||||||
|
65
README.md
65
README.md
@ -2,68 +2,21 @@
|
|||||||
|
|
||||||
Vulkan header files and API registry
|
Vulkan header files and API registry
|
||||||
|
|
||||||
## Default branch changed to 'main' 2021-09-12
|
## Contributing
|
||||||
|
|
||||||
As discussed in #222, the default branch of this repository is now 'main'. This change should be largely transparent to repository users, since github rewrites many references to the old 'master' branch to 'main'. However, if you have a checked-out local clone, you may wish to take the following steps as recommended by github:
|
See the [CONTRIBUTING.md](CONTRIBUTING.md)
|
||||||
|
|
||||||
```sh
|
## Building
|
||||||
git branch -m master main
|
|
||||||
git fetch origin
|
|
||||||
git branch -u origin/main main
|
|
||||||
git remote set-head origin -a
|
|
||||||
```
|
|
||||||
|
|
||||||
## Repository Content
|
See [BUILD.md](BUILD.md)
|
||||||
|
|
||||||
The contents of this repository are largely obtained from other repositories
|
## SDK Support
|
||||||
and are collected, coordinated, and curated here.
|
|
||||||
|
|
||||||
If proposing changes to any file originating from a different repository,
|
Vulkan-Headers are shipped as part of the official [Vulkan-SDK](https://www.lunarg.com/vulkan-sdk/)
|
||||||
please propose such changes in that repository, rather than Vulkan-Headers.
|
|
||||||
Files in this repository originate from:
|
|
||||||
|
|
||||||
### Specification repository (https://github.com/KhronosGroup/Vulkan-Docs)
|
## C/C++ Package Manager Support
|
||||||
|
|
||||||
* registry/cgenerator.py
|
`Vulkan-Headers` are also supported by both [conan](https://conan.io/) & [vcpkg](https://learn.microsoft.com/en-us/vcpkg/).
|
||||||
* registry/spec_tools/conventions.py
|
|
||||||
* registry/generator.py
|
|
||||||
* registry/genvk.py
|
|
||||||
* registry/reg.py
|
|
||||||
* registry/spec_tools/util.py
|
|
||||||
* registry/validusage.json
|
|
||||||
* registry/video.xml
|
|
||||||
* registry/vk.xml
|
|
||||||
* registry/vkconventions.py
|
|
||||||
* All files under include/vulkan/ which are *not* listed explicitly as originating from another repository.
|
|
||||||
|
|
||||||
### This repository (https://github.com/KhronosGroup/Vulkan-Headers)
|
|
||||||
|
|
||||||
* .cmake-format.py
|
|
||||||
* BUILD.gn
|
|
||||||
* BUILD.md
|
|
||||||
* CMakeLists.txt
|
|
||||||
* CODE_OF_CONDUCT.md
|
|
||||||
* LICENSE.txt
|
|
||||||
* README.md
|
|
||||||
* cmake/Copyright_cmake.txt
|
|
||||||
* cmake/cmake_uninstall.cmake.in
|
|
||||||
* Non-API headers (report issues to the [Vulkan-Loader/issues](https://github.com/KhronosGroup/Vulkan-Loader/issues) tracker)
|
|
||||||
* include/vulkan/vk_icd.h
|
|
||||||
* include/vulkan/vk_layer.h
|
|
||||||
* include/vulkan/vk_sdk_platform.h
|
|
||||||
|
|
||||||
### Vulkan C++ Binding Repository (https://github.com/KhronosGroup/Vulkan-Hpp)
|
|
||||||
|
|
||||||
As of the Vulkan-Docs 1.2.182 spec update, the Vulkan-Hpp headers have been
|
|
||||||
split into multiple files. All of those files are now included in this
|
|
||||||
repository.
|
|
||||||
|
|
||||||
* include/vulkan/vulkan.hpp
|
|
||||||
* include/vulkan/vulkan_enums.hpp
|
|
||||||
* include/vulkan/vulkan_funcs.hpp
|
|
||||||
* include/vulkan/vulkan_handles.hpp
|
|
||||||
* include/vulkan/vulkan_raii.hpp
|
|
||||||
* include/vulkan/vulkan_structs.hpp
|
|
||||||
|
|
||||||
## Version Tagging Scheme
|
## Version Tagging Scheme
|
||||||
|
|
||||||
@ -74,5 +27,3 @@ specification release are tagged using the following format:
|
|||||||
**Note**: Marked version releases have undergone thorough testing but do not
|
**Note**: Marked version releases have undergone thorough testing but do not
|
||||||
imply the same quality level as SDK tags. SDK tags follow the
|
imply the same quality level as SDK tags. SDK tags follow the
|
||||||
`sdk-<`_`version`_`>.<`_`patch`_`>` format (e.g., `sdk-1.1.92.0`).
|
`sdk-<`_`version`_`>.<`_`patch`_`>` format (e.g., `sdk-1.1.92.0`).
|
||||||
|
|
||||||
This scheme was adopted following the 1.1.96 Vulkan specification release.
|
|
||||||
|
@ -1,126 +0,0 @@
|
|||||||
CMake - Cross Platform Makefile Generator
|
|
||||||
Copyright 2000-2018 Kitware, Inc. and Contributors
|
|
||||||
All rights reserved.
|
|
||||||
|
|
||||||
Redistribution and use in source and binary forms, with or without
|
|
||||||
modification, are permitted provided that the following conditions
|
|
||||||
are met:
|
|
||||||
|
|
||||||
* Redistributions of source code must retain the above copyright
|
|
||||||
notice, this list of conditions and the following disclaimer.
|
|
||||||
|
|
||||||
* Redistributions in binary form must reproduce the above copyright
|
|
||||||
notice, this list of conditions and the following disclaimer in the
|
|
||||||
documentation and/or other materials provided with the distribution.
|
|
||||||
|
|
||||||
* Neither the name of Kitware, Inc. nor the names of Contributors
|
|
||||||
may be used to endorse or promote products derived from this
|
|
||||||
software without specific prior written permission.
|
|
||||||
|
|
||||||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
|
|
||||||
------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
The following individuals and institutions are among the Contributors:
|
|
||||||
|
|
||||||
* Aaron C. Meadows <cmake@shadowguarddev.com>
|
|
||||||
* Adriaan de Groot <groot@kde.org>
|
|
||||||
* Aleksey Avdeev <solo@altlinux.ru>
|
|
||||||
* Alexander Neundorf <neundorf@kde.org>
|
|
||||||
* Alexander Smorkalov <alexander.smorkalov@itseez.com>
|
|
||||||
* Alexey Sokolov <sokolov@google.com>
|
|
||||||
* Alex Turbov <i.zaufi@gmail.com>
|
|
||||||
* Andreas Pakulat <apaku@gmx.de>
|
|
||||||
* Andreas Schneider <asn@cryptomilk.org>
|
|
||||||
* André Rigland Brodtkorb <Andre.Brodtkorb@ifi.uio.no>
|
|
||||||
* Axel Huebl, Helmholtz-Zentrum Dresden - Rossendorf
|
|
||||||
* Benjamin Eikel
|
|
||||||
* Bjoern Ricks <bjoern.ricks@gmail.com>
|
|
||||||
* Brad Hards <bradh@kde.org>
|
|
||||||
* Christopher Harvey
|
|
||||||
* Christoph Grüninger <foss@grueninger.de>
|
|
||||||
* Clement Creusot <creusot@cs.york.ac.uk>
|
|
||||||
* Daniel Blezek <blezek@gmail.com>
|
|
||||||
* Daniel Pfeifer <daniel@pfeifer-mail.de>
|
|
||||||
* Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de>
|
|
||||||
* Eran Ifrah <eran.ifrah@gmail.com>
|
|
||||||
* Esben Mose Hansen, Ange Optimization ApS
|
|
||||||
* Geoffrey Viola <geoffrey.viola@asirobots.com>
|
|
||||||
* Google Inc
|
|
||||||
* Gregor Jasny
|
|
||||||
* Helio Chissini de Castro <helio@kde.org>
|
|
||||||
* Ilya Lavrenov <ilya.lavrenov@itseez.com>
|
|
||||||
* Insight Software Consortium <insightsoftwareconsortium.org>
|
|
||||||
* Jan Woetzel
|
|
||||||
* Kelly Thompson <kgt@lanl.gov>
|
|
||||||
* Konstantin Podsvirov <konstantin@podsvirov.pro>
|
|
||||||
* Mario Bensi <mbensi@ipsquad.net>
|
|
||||||
* Mathieu Malaterre <mathieu.malaterre@gmail.com>
|
|
||||||
* Matthaeus G. Chajdas
|
|
||||||
* Matthias Kretz <kretz@kde.org>
|
|
||||||
* Matthias Maennich <matthias@maennich.net>
|
|
||||||
* Michael Stürmer
|
|
||||||
* Miguel A. Figueroa-Villanueva
|
|
||||||
* Mike Jackson
|
|
||||||
* Mike McQuaid <mike@mikemcquaid.com>
|
|
||||||
* Nicolas Bock <nicolasbock@gmail.com>
|
|
||||||
* Nicolas Despres <nicolas.despres@gmail.com>
|
|
||||||
* Nikita Krupen'ko <krnekit@gmail.com>
|
|
||||||
* NVIDIA Corporation <www.nvidia.com>
|
|
||||||
* OpenGamma Ltd. <opengamma.com>
|
|
||||||
* Patrick Stotko <stotko@cs.uni-bonn.de>
|
|
||||||
* Per Øyvind Karlsen <peroyvind@mandriva.org>
|
|
||||||
* Peter Collingbourne <peter@pcc.me.uk>
|
|
||||||
* Petr Gotthard <gotthard@honeywell.com>
|
|
||||||
* Philip Lowman <philip@yhbt.com>
|
|
||||||
* Philippe Proulx <pproulx@efficios.com>
|
|
||||||
* Raffi Enficiaud, Max Planck Society
|
|
||||||
* Raumfeld <raumfeld.com>
|
|
||||||
* Roger Leigh <rleigh@codelibre.net>
|
|
||||||
* Rolf Eike Beer <eike@sf-mail.de>
|
|
||||||
* Roman Donchenko <roman.donchenko@itseez.com>
|
|
||||||
* Roman Kharitonov <roman.kharitonov@itseez.com>
|
|
||||||
* Ruslan Baratov
|
|
||||||
* Sebastian Holtermann <sebholt@xwmw.org>
|
|
||||||
* Stephen Kelly <steveire@gmail.com>
|
|
||||||
* Sylvain Joubert <joubert.sy@gmail.com>
|
|
||||||
* Thomas Sondergaard <ts@medical-insight.com>
|
|
||||||
* Tobias Hunger <tobias.hunger@qt.io>
|
|
||||||
* Todd Gamblin <tgamblin@llnl.gov>
|
|
||||||
* Tristan Carel
|
|
||||||
* University of Dundee
|
|
||||||
* Vadim Zhukov
|
|
||||||
* Will Dicharry <wdicharry@stellarscience.com>
|
|
||||||
|
|
||||||
See version control history for details of individual contributions.
|
|
||||||
|
|
||||||
The above copyright and license notice applies to distributions of
|
|
||||||
CMake in source and binary form. Third-party software packages supplied
|
|
||||||
with CMake under compatible licenses provide their own copyright notices
|
|
||||||
documented in corresponding subdirectories or source files.
|
|
||||||
|
|
||||||
------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
CMake was initially developed by Kitware with the following sponsorship:
|
|
||||||
|
|
||||||
* National Library of Medicine at the National Institutes of Health
|
|
||||||
as part of the Insight Segmentation and Registration Toolkit (ITK).
|
|
||||||
|
|
||||||
* US National Labs (Los Alamos, Livermore, Sandia) ASC Parallel
|
|
||||||
Visualization Initiative.
|
|
||||||
|
|
||||||
* National Alliance for Medical Image Computing (NAMIC) is funded by the
|
|
||||||
National Institutes of Health through the NIH Roadmap for Medical Research,
|
|
||||||
Grant U54 EB005149.
|
|
||||||
|
|
||||||
* Kitware, Inc.
|
|
5
cmake/VulkanHeadersConfig.cmake.in
Normal file
5
cmake/VulkanHeadersConfig.cmake.in
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
@PACKAGE_INIT@
|
||||||
|
|
||||||
|
include("${CMAKE_CURRENT_LIST_DIR}/VulkanHeadersTargets.cmake")
|
||||||
|
|
||||||
|
set(VULKAN_HEADERS_REGISTRY_DIRECTORY "@PACKAGE_VULKAN_HEADERS_REGISTRY_DIRECTORY@")
|
@ -1,21 +0,0 @@
|
|||||||
if(NOT EXISTS "@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt")
|
|
||||||
message(FATAL_ERROR "Cannot find install manifest: @CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt")
|
|
||||||
endif(NOT EXISTS "@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt")
|
|
||||||
|
|
||||||
file(READ "@CMAKE_CURRENT_BINARY_DIR@/install_manifest.txt" files)
|
|
||||||
string(REGEX REPLACE "\n" ";" files "${files}")
|
|
||||||
foreach(file ${files})
|
|
||||||
message(STATUS "Uninstalling $ENV{DESTDIR}${file}")
|
|
||||||
if(IS_SYMLINK "$ENV{DESTDIR}${file}" OR EXISTS "$ENV{DESTDIR}${file}")
|
|
||||||
exec_program(
|
|
||||||
"@CMAKE_COMMAND@" ARGS "-E remove \"$ENV{DESTDIR}${file}\""
|
|
||||||
OUTPUT_VARIABLE rm_out
|
|
||||||
RETURN_VALUE rm_retval
|
|
||||||
)
|
|
||||||
if(NOT "${rm_retval}" STREQUAL 0)
|
|
||||||
message(FATAL_ERROR "Problem when removing $ENV{DESTDIR}${file}")
|
|
||||||
endif(NOT "${rm_retval}" STREQUAL 0)
|
|
||||||
else(IS_SYMLINK "$ENV{DESTDIR}${file}" OR EXISTS "$ENV{DESTDIR}${file}")
|
|
||||||
message(STATUS "File $ENV{DESTDIR}${file} does not exist.")
|
|
||||||
endif(IS_SYMLINK "$ENV{DESTDIR}${file}" OR EXISTS "$ENV{DESTDIR}${file}")
|
|
||||||
endforeach(file)
|
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_VIDEO_CODEC_H264STD_H_ 1
|
#define VULKAN_VIDEO_CODEC_H264STD_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_VIDEO_CODEC_H264STD_DECODE_H_ 1
|
#define VULKAN_VIDEO_CODEC_H264STD_DECODE_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
@ -20,11 +20,11 @@ extern "C" {
|
|||||||
|
|
||||||
|
|
||||||
#define vulkan_video_codec_h264std_decode 1
|
#define vulkan_video_codec_h264std_decode 1
|
||||||
// Vulkan 0.9 provisional Vulkan video H.264 decode std specification version number
|
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_API_VERSION_0_9_8 VK_MAKE_VIDEO_STD_VERSION(0, 9, 8) // Patch version should always be set to 0
|
#define VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_API_VERSION_1_0_0 VK_MAKE_VIDEO_STD_VERSION(1, 0, 0)
|
||||||
|
|
||||||
#define STD_VIDEO_DECODE_H264_FIELD_ORDER_COUNT_LIST_SIZE 2
|
#define STD_VIDEO_DECODE_H264_FIELD_ORDER_COUNT_LIST_SIZE 2
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_SPEC_VERSION VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_API_VERSION_0_9_8
|
#define VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_SPEC_VERSION VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_API_VERSION_1_0_0
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_EXTENSION_NAME "VK_STD_vulkan_video_codec_h264_decode"
|
#define VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_EXTENSION_NAME "VK_STD_vulkan_video_codec_h264_decode"
|
||||||
|
|
||||||
typedef enum StdVideoDecodeH264FieldOrderCount {
|
typedef enum StdVideoDecodeH264FieldOrderCount {
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_VIDEO_CODEC_H264STD_ENCODE_H_ 1
|
#define VULKAN_VIDEO_CODEC_H264STD_ENCODE_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
@ -21,9 +21,9 @@ extern "C" {
|
|||||||
|
|
||||||
#define vulkan_video_codec_h264std_encode 1
|
#define vulkan_video_codec_h264std_encode 1
|
||||||
// Vulkan 0.9 provisional Vulkan video H.264 encode std specification version number
|
// Vulkan 0.9 provisional Vulkan video H.264 encode std specification version number
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_API_VERSION_0_9_8 VK_MAKE_VIDEO_STD_VERSION(0, 9, 8) // Patch version should always be set to 0
|
#define VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_API_VERSION_0_9_9 VK_MAKE_VIDEO_STD_VERSION(0, 9, 9)
|
||||||
|
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_SPEC_VERSION VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_API_VERSION_0_9_8
|
#define VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_SPEC_VERSION VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_API_VERSION_0_9_9
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_EXTENSION_NAME "VK_STD_vulkan_video_codec_h264_encode"
|
#define VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_EXTENSION_NAME "VK_STD_vulkan_video_codec_h264_encode"
|
||||||
typedef struct StdVideoEncodeH264WeightTableFlags {
|
typedef struct StdVideoEncodeH264WeightTableFlags {
|
||||||
uint32_t luma_weight_l0_flag;
|
uint32_t luma_weight_l0_flag;
|
||||||
@ -64,10 +64,10 @@ typedef struct StdVideoEncodeH264ReferenceInfoFlags {
|
|||||||
uint32_t used_for_long_term_reference : 1;
|
uint32_t used_for_long_term_reference : 1;
|
||||||
} StdVideoEncodeH264ReferenceInfoFlags;
|
} StdVideoEncodeH264ReferenceInfoFlags;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH264RefMgmtFlags {
|
typedef struct StdVideoEncodeH264ReferenceListsInfoFlags {
|
||||||
uint32_t ref_pic_list_modification_l0_flag : 1;
|
uint32_t ref_pic_list_modification_flag_l0 : 1;
|
||||||
uint32_t ref_pic_list_modification_l1_flag : 1;
|
uint32_t ref_pic_list_modification_flag_l1 : 1;
|
||||||
} StdVideoEncodeH264RefMgmtFlags;
|
} StdVideoEncodeH264ReferenceListsInfoFlags;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH264RefListModEntry {
|
typedef struct StdVideoEncodeH264RefListModEntry {
|
||||||
StdVideoH264ModificationOfPicNumsIdc modification_of_pic_nums_idc;
|
StdVideoH264ModificationOfPicNumsIdc modification_of_pic_nums_idc;
|
||||||
@ -83,20 +83,26 @@ typedef struct StdVideoEncodeH264RefPicMarkingEntry {
|
|||||||
uint16_t max_long_term_frame_idx_plus1;
|
uint16_t max_long_term_frame_idx_plus1;
|
||||||
} StdVideoEncodeH264RefPicMarkingEntry;
|
} StdVideoEncodeH264RefPicMarkingEntry;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH264RefMemMgmtCtrlOperations {
|
typedef struct StdVideoEncodeH264ReferenceListsInfo {
|
||||||
StdVideoEncodeH264RefMgmtFlags flags;
|
StdVideoEncodeH264ReferenceListsInfoFlags flags;
|
||||||
|
uint8_t refPicList0EntryCount;
|
||||||
|
uint8_t refPicList1EntryCount;
|
||||||
uint8_t refList0ModOpCount;
|
uint8_t refList0ModOpCount;
|
||||||
const StdVideoEncodeH264RefListModEntry* pRefList0ModOperations;
|
|
||||||
uint8_t refList1ModOpCount;
|
uint8_t refList1ModOpCount;
|
||||||
const StdVideoEncodeH264RefListModEntry* pRefList1ModOperations;
|
|
||||||
uint8_t refPicMarkingOpCount;
|
uint8_t refPicMarkingOpCount;
|
||||||
|
uint8_t reserved1[7];
|
||||||
|
const uint8_t* pRefPicList0Entries;
|
||||||
|
const uint8_t* pRefPicList1Entries;
|
||||||
|
const StdVideoEncodeH264RefListModEntry* pRefList0ModOperations;
|
||||||
|
const StdVideoEncodeH264RefListModEntry* pRefList1ModOperations;
|
||||||
const StdVideoEncodeH264RefPicMarkingEntry* pRefPicMarkingOperations;
|
const StdVideoEncodeH264RefPicMarkingEntry* pRefPicMarkingOperations;
|
||||||
} StdVideoEncodeH264RefMemMgmtCtrlOperations;
|
} StdVideoEncodeH264ReferenceListsInfo;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH264PictureInfo {
|
typedef struct StdVideoEncodeH264PictureInfo {
|
||||||
StdVideoEncodeH264PictureInfoFlags flags;
|
StdVideoEncodeH264PictureInfoFlags flags;
|
||||||
uint8_t seq_parameter_set_id;
|
uint8_t seq_parameter_set_id;
|
||||||
uint8_t pic_parameter_set_id;
|
uint8_t pic_parameter_set_id;
|
||||||
|
uint16_t reserved1;
|
||||||
StdVideoH264PictureType pictureType;
|
StdVideoH264PictureType pictureType;
|
||||||
uint32_t frame_num;
|
uint32_t frame_num;
|
||||||
int32_t PicOrderCnt;
|
int32_t PicOrderCnt;
|
||||||
@ -104,6 +110,7 @@ typedef struct StdVideoEncodeH264PictureInfo {
|
|||||||
|
|
||||||
typedef struct StdVideoEncodeH264ReferenceInfo {
|
typedef struct StdVideoEncodeH264ReferenceInfo {
|
||||||
StdVideoEncodeH264ReferenceInfoFlags flags;
|
StdVideoEncodeH264ReferenceInfoFlags flags;
|
||||||
|
StdVideoH264PictureType pictureType;
|
||||||
uint32_t FrameNum;
|
uint32_t FrameNum;
|
||||||
int32_t PicOrderCnt;
|
int32_t PicOrderCnt;
|
||||||
uint16_t long_term_pic_num;
|
uint16_t long_term_pic_num;
|
||||||
@ -121,6 +128,8 @@ typedef struct StdVideoEncodeH264SliceHeader {
|
|||||||
StdVideoH264DisableDeblockingFilterIdc disable_deblocking_filter_idc;
|
StdVideoH264DisableDeblockingFilterIdc disable_deblocking_filter_idc;
|
||||||
int8_t slice_alpha_c0_offset_div2;
|
int8_t slice_alpha_c0_offset_div2;
|
||||||
int8_t slice_beta_offset_div2;
|
int8_t slice_beta_offset_div2;
|
||||||
|
uint16_t reserved1;
|
||||||
|
uint32_t reserved2;
|
||||||
const StdVideoEncodeH264WeightTable* pWeightTable;
|
const StdVideoEncodeH264WeightTable* pWeightTable;
|
||||||
} StdVideoEncodeH264SliceHeader;
|
} StdVideoEncodeH264SliceHeader;
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_VIDEO_CODEC_H265STD_H_ 1
|
#define VULKAN_VIDEO_CODEC_H265STD_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_VIDEO_CODEC_H265STD_DECODE_H_ 1
|
#define VULKAN_VIDEO_CODEC_H265STD_DECODE_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
@ -20,11 +20,11 @@ extern "C" {
|
|||||||
|
|
||||||
|
|
||||||
#define vulkan_video_codec_h265std_decode 1
|
#define vulkan_video_codec_h265std_decode 1
|
||||||
// Vulkan 0.9 provisional Vulkan video H.265 decode std specification version number
|
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_API_VERSION_0_9_9 VK_MAKE_VIDEO_STD_VERSION(0, 9, 9) // Patch version should always be set to 0
|
#define VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_API_VERSION_1_0_0 VK_MAKE_VIDEO_STD_VERSION(1, 0, 0)
|
||||||
|
|
||||||
#define STD_VIDEO_DECODE_H265_REF_PIC_SET_LIST_SIZE 8
|
#define STD_VIDEO_DECODE_H265_REF_PIC_SET_LIST_SIZE 8
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_SPEC_VERSION VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_API_VERSION_0_9_9
|
#define VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_SPEC_VERSION VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_API_VERSION_1_0_0
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_EXTENSION_NAME "VK_STD_vulkan_video_codec_h265_decode"
|
#define VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_EXTENSION_NAME "VK_STD_vulkan_video_codec_h265_decode"
|
||||||
typedef struct StdVideoDecodeH265PictureInfoFlags {
|
typedef struct StdVideoDecodeH265PictureInfoFlags {
|
||||||
uint32_t IrapPicFlag : 1;
|
uint32_t IrapPicFlag : 1;
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_VIDEO_CODEC_H265STD_ENCODE_H_ 1
|
#define VULKAN_VIDEO_CODEC_H265STD_ENCODE_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
@ -21,9 +21,9 @@ extern "C" {
|
|||||||
|
|
||||||
#define vulkan_video_codec_h265std_encode 1
|
#define vulkan_video_codec_h265std_encode 1
|
||||||
// Vulkan 0.9 provisional Vulkan video H.265 encode std specification version number
|
// Vulkan 0.9 provisional Vulkan video H.265 encode std specification version number
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_API_VERSION_0_9_9 VK_MAKE_VIDEO_STD_VERSION(0, 9, 9) // Patch version should always be set to 0
|
#define VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_API_VERSION_0_9_10 VK_MAKE_VIDEO_STD_VERSION(0, 9, 10)
|
||||||
|
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_SPEC_VERSION VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_API_VERSION_0_9_9
|
#define VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_SPEC_VERSION VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_API_VERSION_0_9_10
|
||||||
#define VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_EXTENSION_NAME "VK_STD_vulkan_video_codec_h265_encode"
|
#define VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_EXTENSION_NAME "VK_STD_vulkan_video_codec_h265_encode"
|
||||||
typedef struct StdVideoEncodeH265WeightTableFlags {
|
typedef struct StdVideoEncodeH265WeightTableFlags {
|
||||||
uint16_t luma_weight_l0_flag;
|
uint16_t luma_weight_l0_flag;
|
||||||
@ -96,18 +96,21 @@ typedef struct StdVideoEncodeH265SliceSegmentHeader {
|
|||||||
const StdVideoEncodeH265WeightTable* pWeightTable;
|
const StdVideoEncodeH265WeightTable* pWeightTable;
|
||||||
} StdVideoEncodeH265SliceSegmentHeader;
|
} StdVideoEncodeH265SliceSegmentHeader;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH265ReferenceModificationFlags {
|
typedef struct StdVideoEncodeH265ReferenceListsInfoFlags {
|
||||||
uint32_t ref_pic_list_modification_flag_l0 : 1;
|
uint32_t ref_pic_list_modification_flag_l0 : 1;
|
||||||
uint32_t ref_pic_list_modification_flag_l1 : 1;
|
uint32_t ref_pic_list_modification_flag_l1 : 1;
|
||||||
} StdVideoEncodeH265ReferenceModificationFlags;
|
} StdVideoEncodeH265ReferenceListsInfoFlags;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH265ReferenceModifications {
|
typedef struct StdVideoEncodeH265ReferenceListsInfo {
|
||||||
StdVideoEncodeH265ReferenceModificationFlags flags;
|
StdVideoEncodeH265ReferenceListsInfoFlags flags;
|
||||||
uint8_t referenceList0ModificationsCount;
|
uint8_t num_ref_idx_l0_active_minus1;
|
||||||
const uint8_t* pReferenceList0Modifications;
|
uint8_t num_ref_idx_l1_active_minus1;
|
||||||
uint8_t referenceList1ModificationsCount;
|
uint16_t reserved1;
|
||||||
const uint8_t* pReferenceList1Modifications;
|
const uint8_t* pRefPicList0Entries;
|
||||||
} StdVideoEncodeH265ReferenceModifications;
|
const uint8_t* pRefPicList1Entries;
|
||||||
|
const uint8_t* pRefList0Modifications;
|
||||||
|
const uint8_t* pRefList1Modifications;
|
||||||
|
} StdVideoEncodeH265ReferenceListsInfo;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH265PictureInfoFlags {
|
typedef struct StdVideoEncodeH265PictureInfoFlags {
|
||||||
uint32_t is_reference_flag : 1;
|
uint32_t is_reference_flag : 1;
|
||||||
@ -123,8 +126,8 @@ typedef struct StdVideoEncodeH265PictureInfo {
|
|||||||
uint8_t sps_video_parameter_set_id;
|
uint8_t sps_video_parameter_set_id;
|
||||||
uint8_t pps_seq_parameter_set_id;
|
uint8_t pps_seq_parameter_set_id;
|
||||||
uint8_t pps_pic_parameter_set_id;
|
uint8_t pps_pic_parameter_set_id;
|
||||||
int32_t PicOrderCntVal;
|
|
||||||
uint8_t TemporalId;
|
uint8_t TemporalId;
|
||||||
|
int32_t PicOrderCntVal;
|
||||||
} StdVideoEncodeH265PictureInfo;
|
} StdVideoEncodeH265PictureInfo;
|
||||||
|
|
||||||
typedef struct StdVideoEncodeH265ReferenceInfoFlags {
|
typedef struct StdVideoEncodeH265ReferenceInfoFlags {
|
||||||
@ -134,6 +137,7 @@ typedef struct StdVideoEncodeH265ReferenceInfoFlags {
|
|||||||
|
|
||||||
typedef struct StdVideoEncodeH265ReferenceInfo {
|
typedef struct StdVideoEncodeH265ReferenceInfo {
|
||||||
StdVideoEncodeH265ReferenceInfoFlags flags;
|
StdVideoEncodeH265ReferenceInfoFlags flags;
|
||||||
|
StdVideoH265PictureType PictureType;
|
||||||
int32_t PicOrderCntVal;
|
int32_t PicOrderCntVal;
|
||||||
uint8_t TemporalId;
|
uint8_t TemporalId;
|
||||||
} StdVideoEncodeH265ReferenceInfo;
|
} StdVideoEncodeH265ReferenceInfo;
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_VIDEO_CODECS_COMMON_H_ 1
|
#define VULKAN_VIDEO_CODECS_COMMON_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
@ -2,9 +2,9 @@
|
|||||||
// File: vk_icd.h
|
// File: vk_icd.h
|
||||||
//
|
//
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2015-2016 The Khronos Group Inc.
|
* Copyright (c) 2015-2023 LunarG, Inc.
|
||||||
* Copyright (c) 2015-2016 Valve Corporation
|
* Copyright (c) 2015-2023 The Khronos Group Inc.
|
||||||
* Copyright (c) 2015-2016 LunarG, Inc.
|
* Copyright (c) 2015-2023 Valve Corporation
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
@ -19,9 +19,7 @@
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
#pragma once
|
||||||
#ifndef VKICD_H
|
|
||||||
#define VKICD_H
|
|
||||||
|
|
||||||
#include "vulkan.h"
|
#include "vulkan.h"
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
@ -42,7 +40,17 @@
|
|||||||
// call for any API version > 1.0. Otherwise, the loader will
|
// call for any API version > 1.0. Otherwise, the loader will
|
||||||
// manually determine if it can support the expected version.
|
// manually determine if it can support the expected version.
|
||||||
// Version 6 - Add support for vk_icdEnumerateAdapterPhysicalDevices.
|
// Version 6 - Add support for vk_icdEnumerateAdapterPhysicalDevices.
|
||||||
#define CURRENT_LOADER_ICD_INTERFACE_VERSION 6
|
// Version 7 - If an ICD supports any of the following functions, they must be
|
||||||
|
// queryable with vk_icdGetInstanceProcAddr:
|
||||||
|
// vk_icdNegotiateLoaderICDInterfaceVersion
|
||||||
|
// vk_icdGetPhysicalDeviceProcAddr
|
||||||
|
// vk_icdEnumerateAdapterPhysicalDevices (Windows only)
|
||||||
|
// In addition, these functions no longer need to be exported directly.
|
||||||
|
// This version allows drivers provided through the extension
|
||||||
|
// VK_LUNARG_direct_driver_loading be able to support the entire
|
||||||
|
// Driver-Loader interface.
|
||||||
|
|
||||||
|
#define CURRENT_LOADER_ICD_INTERFACE_VERSION 7
|
||||||
#define MIN_SUPPORTED_LOADER_ICD_INTERFACE_VERSION 0
|
#define MIN_SUPPORTED_LOADER_ICD_INTERFACE_VERSION 0
|
||||||
#define MIN_PHYS_DEV_EXTENSION_ICD_INTERFACE_VERSION 4
|
#define MIN_PHYS_DEV_EXTENSION_ICD_INTERFACE_VERSION 4
|
||||||
|
|
||||||
@ -70,7 +78,7 @@ extern "C" {
|
|||||||
#endif
|
#endif
|
||||||
VKAPI_ATTR VkResult VKAPI_CALL vk_icdNegotiateLoaderICDInterfaceVersion(uint32_t* pVersion);
|
VKAPI_ATTR VkResult VKAPI_CALL vk_icdNegotiateLoaderICDInterfaceVersion(uint32_t* pVersion);
|
||||||
VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL vk_icdGetInstanceProcAddr(VkInstance instance, const char* pName);
|
VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL vk_icdGetInstanceProcAddr(VkInstance instance, const char* pName);
|
||||||
VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL vk_icdGetPhysicalDeviceProcAddr(VkInstance isntance, const char* pName);
|
VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL vk_icdGetPhysicalDeviceProcAddr(VkInstance instance, const char* pName);
|
||||||
#if defined(VK_USE_PLATFORM_WIN32_KHR)
|
#if defined(VK_USE_PLATFORM_WIN32_KHR)
|
||||||
VKAPI_ATTR VkResult VKAPI_CALL vk_icdEnumerateAdapterPhysicalDevices(VkInstance instance, LUID adapterLUID,
|
VKAPI_ATTR VkResult VKAPI_CALL vk_icdEnumerateAdapterPhysicalDevices(VkInstance instance, LUID adapterLUID,
|
||||||
uint32_t* pPhysicalDeviceCount, VkPhysicalDevice* pPhysicalDevices);
|
uint32_t* pPhysicalDeviceCount, VkPhysicalDevice* pPhysicalDevices);
|
||||||
@ -123,6 +131,7 @@ typedef enum {
|
|||||||
VK_ICD_WSI_PLATFORM_VI,
|
VK_ICD_WSI_PLATFORM_VI,
|
||||||
VK_ICD_WSI_PLATFORM_GGP,
|
VK_ICD_WSI_PLATFORM_GGP,
|
||||||
VK_ICD_WSI_PLATFORM_SCREEN,
|
VK_ICD_WSI_PLATFORM_SCREEN,
|
||||||
|
VK_ICD_WSI_PLATFORM_FUCHSIA,
|
||||||
VK_ICD_WSI_PLATFORM_OHOS,
|
VK_ICD_WSI_PLATFORM_OHOS,
|
||||||
} VkIcdWsiPlatform;
|
} VkIcdWsiPlatform;
|
||||||
|
|
||||||
@ -243,10 +252,15 @@ typedef struct {
|
|||||||
} VkIcdSurfaceScreen;
|
} VkIcdSurfaceScreen;
|
||||||
#endif // VK_USE_PLATFORM_SCREEN_QNX
|
#endif // VK_USE_PLATFORM_SCREEN_QNX
|
||||||
|
|
||||||
|
#ifdef VK_USE_PLATFORM_FUCHSIA
|
||||||
|
typedef struct {
|
||||||
|
VkIcdSurfaceBase base;
|
||||||
|
} VkIcdSurfaceImagePipe;
|
||||||
|
#endif // VK_USE_PLATFORM_FUCHSIA
|
||||||
|
|
||||||
#ifdef VK_USE_PLATFORM_OHOS
|
#ifdef VK_USE_PLATFORM_OHOS
|
||||||
typedef struct {
|
typedef struct {
|
||||||
VkIcdSurfaceBase base;
|
VkIcdSurfaceBase base;
|
||||||
struct NativeWindow *window;
|
struct NativeWindow *window;
|
||||||
} VkIcdSurfaceOHOS;
|
} VkIcdSurfaceOHOS;
|
||||||
#endif // VK_USE_PLATFORM_OHOS
|
#endif // VK_USE_PLATFORM_OHOS
|
||||||
#endif // VKICD_H
|
|
||||||
|
@ -2,9 +2,9 @@
|
|||||||
// File: vk_layer.h
|
// File: vk_layer.h
|
||||||
//
|
//
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2015-2017 The Khronos Group Inc.
|
* Copyright (c) 2015-2023 LunarG, Inc.
|
||||||
* Copyright (c) 2015-2017 Valve Corporation
|
* Copyright (c) 2015-2023 The Khronos Group Inc.
|
||||||
* Copyright (c) 2015-2017 LunarG, Inc.
|
* Copyright (c) 2015-2023 Valve Corporation
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
@ -19,21 +19,14 @@
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
#pragma once
|
||||||
|
|
||||||
/* Need to define dispatch table
|
/* Need to define dispatch table
|
||||||
* Core struct can then have ptr to dispatch table at the top
|
* Core struct can then have ptr to dispatch table at the top
|
||||||
* Along with object ptrs for current and next OBJ
|
* Along with object ptrs for current and next OBJ
|
||||||
*/
|
*/
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#include "vulkan.h"
|
#include "vulkan_core.h"
|
||||||
#if defined(__GNUC__) && __GNUC__ >= 4
|
|
||||||
#define VK_LAYER_EXPORT __attribute__((visibility("default")))
|
|
||||||
#elif defined(__SUNPRO_C) && (__SUNPRO_C >= 0x590)
|
|
||||||
#define VK_LAYER_EXPORT __attribute__((visibility("default")))
|
|
||||||
#else
|
|
||||||
#define VK_LAYER_EXPORT
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define MAX_NUM_UNKNOWN_EXTS 250
|
#define MAX_NUM_UNKNOWN_EXTS 250
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
// File: vk_platform.h
|
// File: vk_platform.h
|
||||||
//
|
//
|
||||||
/*
|
/*
|
||||||
** Copyright 2014-2022 The Khronos Group Inc.
|
** Copyright 2014-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
@ -1,69 +0,0 @@
|
|||||||
//
|
|
||||||
// File: vk_sdk_platform.h
|
|
||||||
//
|
|
||||||
/*
|
|
||||||
* Copyright (c) 2015-2016 The Khronos Group Inc.
|
|
||||||
* Copyright (c) 2015-2016 Valve Corporation
|
|
||||||
* Copyright (c) 2015-2016 LunarG, Inc.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef VK_SDK_PLATFORM_H
|
|
||||||
#define VK_SDK_PLATFORM_H
|
|
||||||
|
|
||||||
#if defined(_WIN32)
|
|
||||||
#define NOMINMAX
|
|
||||||
#ifndef __cplusplus
|
|
||||||
#undef inline
|
|
||||||
#define inline __inline
|
|
||||||
#endif // __cplusplus
|
|
||||||
|
|
||||||
#if (defined(_MSC_VER) && _MSC_VER < 1900 /*vs2015*/)
|
|
||||||
// C99:
|
|
||||||
// Microsoft didn't implement C99 in Visual Studio; but started adding it with
|
|
||||||
// VS2013. However, VS2013 still didn't have snprintf(). The following is a
|
|
||||||
// work-around (Note: The _CRT_SECURE_NO_WARNINGS macro must be set in the
|
|
||||||
// "CMakeLists.txt" file).
|
|
||||||
// NOTE: This is fixed in Visual Studio 2015.
|
|
||||||
#define snprintf _snprintf
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define strdup _strdup
|
|
||||||
|
|
||||||
#endif // _WIN32
|
|
||||||
|
|
||||||
// Check for noexcept support using clang, with fallback to Windows or GCC version numbers
|
|
||||||
#ifndef NOEXCEPT
|
|
||||||
#if defined(__clang__)
|
|
||||||
#if __has_feature(cxx_noexcept)
|
|
||||||
#define HAS_NOEXCEPT
|
|
||||||
#endif
|
|
||||||
#else
|
|
||||||
#if defined(__GXX_EXPERIMENTAL_CXX0X__) && __GNUC__ * 10 + __GNUC_MINOR__ >= 46
|
|
||||||
#define HAS_NOEXCEPT
|
|
||||||
#else
|
|
||||||
#if defined(_MSC_FULL_VER) && _MSC_FULL_VER >= 190023026 && defined(_HAS_EXCEPTIONS) && _HAS_EXCEPTIONS
|
|
||||||
#define HAS_NOEXCEPT
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef HAS_NOEXCEPT
|
|
||||||
#define NOEXCEPT noexcept
|
|
||||||
#else
|
|
||||||
#define NOEXCEPT
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif // VK_SDK_PLATFORM_H
|
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_H_ 1
|
#define VULKAN_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
@ -84,6 +84,14 @@
|
|||||||
#include "vulkan_screen.h"
|
#include "vulkan_screen.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef VK_USE_PLATFORM_SCI
|
||||||
|
#include <nvscisync.h>
|
||||||
|
#include <nvscibuf.h>
|
||||||
|
#include "vulkan_sci.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#ifdef VK_ENABLE_BETA_EXTENSIONS
|
#ifdef VK_ENABLE_BETA_EXTENSIONS
|
||||||
#include "vulkan_beta.h"
|
#include "vulkan_beta.h"
|
||||||
#endif
|
#endif
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_ANDROID_H_ 1
|
#define VULKAN_ANDROID_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_BETA_H_ 1
|
#define VULKAN_BETA_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
@ -19,356 +19,6 @@ extern "C" {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_KHR_video_queue 1
|
|
||||||
VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkVideoSessionKHR)
|
|
||||||
VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkVideoSessionParametersKHR)
|
|
||||||
#define VK_KHR_VIDEO_QUEUE_SPEC_VERSION 7
|
|
||||||
#define VK_KHR_VIDEO_QUEUE_EXTENSION_NAME "VK_KHR_video_queue"
|
|
||||||
|
|
||||||
typedef enum VkQueryResultStatusKHR {
|
|
||||||
VK_QUERY_RESULT_STATUS_ERROR_KHR = -1,
|
|
||||||
VK_QUERY_RESULT_STATUS_NOT_READY_KHR = 0,
|
|
||||||
VK_QUERY_RESULT_STATUS_COMPLETE_KHR = 1,
|
|
||||||
VK_QUERY_RESULT_STATUS_MAX_ENUM_KHR = 0x7FFFFFFF
|
|
||||||
} VkQueryResultStatusKHR;
|
|
||||||
|
|
||||||
typedef enum VkVideoCodecOperationFlagBitsKHR {
|
|
||||||
VK_VIDEO_CODEC_OPERATION_NONE_KHR = 0,
|
|
||||||
#ifdef VK_ENABLE_BETA_EXTENSIONS
|
|
||||||
VK_VIDEO_CODEC_OPERATION_ENCODE_H264_BIT_EXT = 0x00010000,
|
|
||||||
#endif
|
|
||||||
#ifdef VK_ENABLE_BETA_EXTENSIONS
|
|
||||||
VK_VIDEO_CODEC_OPERATION_ENCODE_H265_BIT_EXT = 0x00020000,
|
|
||||||
#endif
|
|
||||||
#ifdef VK_ENABLE_BETA_EXTENSIONS
|
|
||||||
VK_VIDEO_CODEC_OPERATION_DECODE_H264_BIT_EXT = 0x00000001,
|
|
||||||
#endif
|
|
||||||
#ifdef VK_ENABLE_BETA_EXTENSIONS
|
|
||||||
VK_VIDEO_CODEC_OPERATION_DECODE_H265_BIT_EXT = 0x00000002,
|
|
||||||
#endif
|
|
||||||
VK_VIDEO_CODEC_OPERATION_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
|
||||||
} VkVideoCodecOperationFlagBitsKHR;
|
|
||||||
typedef VkFlags VkVideoCodecOperationFlagsKHR;
|
|
||||||
|
|
||||||
typedef enum VkVideoChromaSubsamplingFlagBitsKHR {
|
|
||||||
VK_VIDEO_CHROMA_SUBSAMPLING_INVALID_KHR = 0,
|
|
||||||
VK_VIDEO_CHROMA_SUBSAMPLING_MONOCHROME_BIT_KHR = 0x00000001,
|
|
||||||
VK_VIDEO_CHROMA_SUBSAMPLING_420_BIT_KHR = 0x00000002,
|
|
||||||
VK_VIDEO_CHROMA_SUBSAMPLING_422_BIT_KHR = 0x00000004,
|
|
||||||
VK_VIDEO_CHROMA_SUBSAMPLING_444_BIT_KHR = 0x00000008,
|
|
||||||
VK_VIDEO_CHROMA_SUBSAMPLING_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
|
||||||
} VkVideoChromaSubsamplingFlagBitsKHR;
|
|
||||||
typedef VkFlags VkVideoChromaSubsamplingFlagsKHR;
|
|
||||||
|
|
||||||
typedef enum VkVideoComponentBitDepthFlagBitsKHR {
|
|
||||||
VK_VIDEO_COMPONENT_BIT_DEPTH_INVALID_KHR = 0,
|
|
||||||
VK_VIDEO_COMPONENT_BIT_DEPTH_8_BIT_KHR = 0x00000001,
|
|
||||||
VK_VIDEO_COMPONENT_BIT_DEPTH_10_BIT_KHR = 0x00000004,
|
|
||||||
VK_VIDEO_COMPONENT_BIT_DEPTH_12_BIT_KHR = 0x00000010,
|
|
||||||
VK_VIDEO_COMPONENT_BIT_DEPTH_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
|
||||||
} VkVideoComponentBitDepthFlagBitsKHR;
|
|
||||||
typedef VkFlags VkVideoComponentBitDepthFlagsKHR;
|
|
||||||
|
|
||||||
typedef enum VkVideoCapabilityFlagBitsKHR {
|
|
||||||
VK_VIDEO_CAPABILITY_PROTECTED_CONTENT_BIT_KHR = 0x00000001,
|
|
||||||
VK_VIDEO_CAPABILITY_SEPARATE_REFERENCE_IMAGES_BIT_KHR = 0x00000002,
|
|
||||||
VK_VIDEO_CAPABILITY_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
|
||||||
} VkVideoCapabilityFlagBitsKHR;
|
|
||||||
typedef VkFlags VkVideoCapabilityFlagsKHR;
|
|
||||||
|
|
||||||
typedef enum VkVideoSessionCreateFlagBitsKHR {
|
|
||||||
VK_VIDEO_SESSION_CREATE_PROTECTED_CONTENT_BIT_KHR = 0x00000001,
|
|
||||||
VK_VIDEO_SESSION_CREATE_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
|
||||||
} VkVideoSessionCreateFlagBitsKHR;
|
|
||||||
typedef VkFlags VkVideoSessionCreateFlagsKHR;
|
|
||||||
typedef VkFlags VkVideoSessionParametersCreateFlagsKHR;
|
|
||||||
typedef VkFlags VkVideoBeginCodingFlagsKHR;
|
|
||||||
typedef VkFlags VkVideoEndCodingFlagsKHR;
|
|
||||||
|
|
||||||
typedef enum VkVideoCodingControlFlagBitsKHR {
|
|
||||||
VK_VIDEO_CODING_CONTROL_RESET_BIT_KHR = 0x00000001,
|
|
||||||
#ifdef VK_ENABLE_BETA_EXTENSIONS
|
|
||||||
VK_VIDEO_CODING_CONTROL_ENCODE_RATE_CONTROL_BIT_KHR = 0x00000002,
|
|
||||||
#endif
|
|
||||||
#ifdef VK_ENABLE_BETA_EXTENSIONS
|
|
||||||
VK_VIDEO_CODING_CONTROL_ENCODE_RATE_CONTROL_LAYER_BIT_KHR = 0x00000004,
|
|
||||||
#endif
|
|
||||||
VK_VIDEO_CODING_CONTROL_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
|
||||||
} VkVideoCodingControlFlagBitsKHR;
|
|
||||||
typedef VkFlags VkVideoCodingControlFlagsKHR;
|
|
||||||
typedef struct VkQueueFamilyQueryResultStatusPropertiesKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
void* pNext;
|
|
||||||
VkBool32 queryResultStatusSupport;
|
|
||||||
} VkQueueFamilyQueryResultStatusPropertiesKHR;
|
|
||||||
|
|
||||||
typedef struct VkQueueFamilyVideoPropertiesKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
void* pNext;
|
|
||||||
VkVideoCodecOperationFlagsKHR videoCodecOperations;
|
|
||||||
} VkQueueFamilyVideoPropertiesKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoProfileInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
VkVideoCodecOperationFlagBitsKHR videoCodecOperation;
|
|
||||||
VkVideoChromaSubsamplingFlagsKHR chromaSubsampling;
|
|
||||||
VkVideoComponentBitDepthFlagsKHR lumaBitDepth;
|
|
||||||
VkVideoComponentBitDepthFlagsKHR chromaBitDepth;
|
|
||||||
} VkVideoProfileInfoKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoProfileListInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
uint32_t profileCount;
|
|
||||||
const VkVideoProfileInfoKHR* pProfiles;
|
|
||||||
} VkVideoProfileListInfoKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoCapabilitiesKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
void* pNext;
|
|
||||||
VkVideoCapabilityFlagsKHR flags;
|
|
||||||
VkDeviceSize minBitstreamBufferOffsetAlignment;
|
|
||||||
VkDeviceSize minBitstreamBufferSizeAlignment;
|
|
||||||
VkExtent2D pictureAccessGranularity;
|
|
||||||
VkExtent2D minCodedExtent;
|
|
||||||
VkExtent2D maxCodedExtent;
|
|
||||||
uint32_t maxDpbSlots;
|
|
||||||
uint32_t maxActiveReferencePictures;
|
|
||||||
VkExtensionProperties stdHeaderVersion;
|
|
||||||
} VkVideoCapabilitiesKHR;
|
|
||||||
|
|
||||||
typedef struct VkPhysicalDeviceVideoFormatInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
VkImageUsageFlags imageUsage;
|
|
||||||
} VkPhysicalDeviceVideoFormatInfoKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoFormatPropertiesKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
void* pNext;
|
|
||||||
VkFormat format;
|
|
||||||
VkComponentMapping componentMapping;
|
|
||||||
VkImageCreateFlags imageCreateFlags;
|
|
||||||
VkImageType imageType;
|
|
||||||
VkImageTiling imageTiling;
|
|
||||||
VkImageUsageFlags imageUsageFlags;
|
|
||||||
} VkVideoFormatPropertiesKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoPictureResourceInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
VkOffset2D codedOffset;
|
|
||||||
VkExtent2D codedExtent;
|
|
||||||
uint32_t baseArrayLayer;
|
|
||||||
VkImageView imageViewBinding;
|
|
||||||
} VkVideoPictureResourceInfoKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoReferenceSlotInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
int32_t slotIndex;
|
|
||||||
const VkVideoPictureResourceInfoKHR* pPictureResource;
|
|
||||||
} VkVideoReferenceSlotInfoKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoSessionMemoryRequirementsKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
void* pNext;
|
|
||||||
uint32_t memoryBindIndex;
|
|
||||||
VkMemoryRequirements memoryRequirements;
|
|
||||||
} VkVideoSessionMemoryRequirementsKHR;
|
|
||||||
|
|
||||||
typedef struct VkBindVideoSessionMemoryInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
uint32_t memoryBindIndex;
|
|
||||||
VkDeviceMemory memory;
|
|
||||||
VkDeviceSize memoryOffset;
|
|
||||||
VkDeviceSize memorySize;
|
|
||||||
} VkBindVideoSessionMemoryInfoKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoSessionCreateInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
uint32_t queueFamilyIndex;
|
|
||||||
VkVideoSessionCreateFlagsKHR flags;
|
|
||||||
const VkVideoProfileInfoKHR* pVideoProfile;
|
|
||||||
VkFormat pictureFormat;
|
|
||||||
VkExtent2D maxCodedExtent;
|
|
||||||
VkFormat referencePictureFormat;
|
|
||||||
uint32_t maxDpbSlots;
|
|
||||||
uint32_t maxActiveReferencePictures;
|
|
||||||
const VkExtensionProperties* pStdHeaderVersion;
|
|
||||||
} VkVideoSessionCreateInfoKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoSessionParametersCreateInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
VkVideoSessionParametersCreateFlagsKHR flags;
|
|
||||||
VkVideoSessionParametersKHR videoSessionParametersTemplate;
|
|
||||||
VkVideoSessionKHR videoSession;
|
|
||||||
} VkVideoSessionParametersCreateInfoKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoSessionParametersUpdateInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
uint32_t updateSequenceCount;
|
|
||||||
} VkVideoSessionParametersUpdateInfoKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoBeginCodingInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
VkVideoBeginCodingFlagsKHR flags;
|
|
||||||
VkVideoSessionKHR videoSession;
|
|
||||||
VkVideoSessionParametersKHR videoSessionParameters;
|
|
||||||
uint32_t referenceSlotCount;
|
|
||||||
const VkVideoReferenceSlotInfoKHR* pReferenceSlots;
|
|
||||||
} VkVideoBeginCodingInfoKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoEndCodingInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
VkVideoEndCodingFlagsKHR flags;
|
|
||||||
} VkVideoEndCodingInfoKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoCodingControlInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
VkVideoCodingControlFlagsKHR flags;
|
|
||||||
} VkVideoCodingControlInfoKHR;
|
|
||||||
|
|
||||||
typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceVideoCapabilitiesKHR)(VkPhysicalDevice physicalDevice, const VkVideoProfileInfoKHR* pVideoProfile, VkVideoCapabilitiesKHR* pCapabilities);
|
|
||||||
typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceVideoFormatPropertiesKHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceVideoFormatInfoKHR* pVideoFormatInfo, uint32_t* pVideoFormatPropertyCount, VkVideoFormatPropertiesKHR* pVideoFormatProperties);
|
|
||||||
typedef VkResult (VKAPI_PTR *PFN_vkCreateVideoSessionKHR)(VkDevice device, const VkVideoSessionCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkVideoSessionKHR* pVideoSession);
|
|
||||||
typedef void (VKAPI_PTR *PFN_vkDestroyVideoSessionKHR)(VkDevice device, VkVideoSessionKHR videoSession, const VkAllocationCallbacks* pAllocator);
|
|
||||||
typedef VkResult (VKAPI_PTR *PFN_vkGetVideoSessionMemoryRequirementsKHR)(VkDevice device, VkVideoSessionKHR videoSession, uint32_t* pMemoryRequirementsCount, VkVideoSessionMemoryRequirementsKHR* pMemoryRequirements);
|
|
||||||
typedef VkResult (VKAPI_PTR *PFN_vkBindVideoSessionMemoryKHR)(VkDevice device, VkVideoSessionKHR videoSession, uint32_t bindSessionMemoryInfoCount, const VkBindVideoSessionMemoryInfoKHR* pBindSessionMemoryInfos);
|
|
||||||
typedef VkResult (VKAPI_PTR *PFN_vkCreateVideoSessionParametersKHR)(VkDevice device, const VkVideoSessionParametersCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkVideoSessionParametersKHR* pVideoSessionParameters);
|
|
||||||
typedef VkResult (VKAPI_PTR *PFN_vkUpdateVideoSessionParametersKHR)(VkDevice device, VkVideoSessionParametersKHR videoSessionParameters, const VkVideoSessionParametersUpdateInfoKHR* pUpdateInfo);
|
|
||||||
typedef void (VKAPI_PTR *PFN_vkDestroyVideoSessionParametersKHR)(VkDevice device, VkVideoSessionParametersKHR videoSessionParameters, const VkAllocationCallbacks* pAllocator);
|
|
||||||
typedef void (VKAPI_PTR *PFN_vkCmdBeginVideoCodingKHR)(VkCommandBuffer commandBuffer, const VkVideoBeginCodingInfoKHR* pBeginInfo);
|
|
||||||
typedef void (VKAPI_PTR *PFN_vkCmdEndVideoCodingKHR)(VkCommandBuffer commandBuffer, const VkVideoEndCodingInfoKHR* pEndCodingInfo);
|
|
||||||
typedef void (VKAPI_PTR *PFN_vkCmdControlVideoCodingKHR)(VkCommandBuffer commandBuffer, const VkVideoCodingControlInfoKHR* pCodingControlInfo);
|
|
||||||
|
|
||||||
#ifndef VK_NO_PROTOTYPES
|
|
||||||
VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceVideoCapabilitiesKHR(
|
|
||||||
VkPhysicalDevice physicalDevice,
|
|
||||||
const VkVideoProfileInfoKHR* pVideoProfile,
|
|
||||||
VkVideoCapabilitiesKHR* pCapabilities);
|
|
||||||
|
|
||||||
VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceVideoFormatPropertiesKHR(
|
|
||||||
VkPhysicalDevice physicalDevice,
|
|
||||||
const VkPhysicalDeviceVideoFormatInfoKHR* pVideoFormatInfo,
|
|
||||||
uint32_t* pVideoFormatPropertyCount,
|
|
||||||
VkVideoFormatPropertiesKHR* pVideoFormatProperties);
|
|
||||||
|
|
||||||
VKAPI_ATTR VkResult VKAPI_CALL vkCreateVideoSessionKHR(
|
|
||||||
VkDevice device,
|
|
||||||
const VkVideoSessionCreateInfoKHR* pCreateInfo,
|
|
||||||
const VkAllocationCallbacks* pAllocator,
|
|
||||||
VkVideoSessionKHR* pVideoSession);
|
|
||||||
|
|
||||||
VKAPI_ATTR void VKAPI_CALL vkDestroyVideoSessionKHR(
|
|
||||||
VkDevice device,
|
|
||||||
VkVideoSessionKHR videoSession,
|
|
||||||
const VkAllocationCallbacks* pAllocator);
|
|
||||||
|
|
||||||
VKAPI_ATTR VkResult VKAPI_CALL vkGetVideoSessionMemoryRequirementsKHR(
|
|
||||||
VkDevice device,
|
|
||||||
VkVideoSessionKHR videoSession,
|
|
||||||
uint32_t* pMemoryRequirementsCount,
|
|
||||||
VkVideoSessionMemoryRequirementsKHR* pMemoryRequirements);
|
|
||||||
|
|
||||||
VKAPI_ATTR VkResult VKAPI_CALL vkBindVideoSessionMemoryKHR(
|
|
||||||
VkDevice device,
|
|
||||||
VkVideoSessionKHR videoSession,
|
|
||||||
uint32_t bindSessionMemoryInfoCount,
|
|
||||||
const VkBindVideoSessionMemoryInfoKHR* pBindSessionMemoryInfos);
|
|
||||||
|
|
||||||
VKAPI_ATTR VkResult VKAPI_CALL vkCreateVideoSessionParametersKHR(
|
|
||||||
VkDevice device,
|
|
||||||
const VkVideoSessionParametersCreateInfoKHR* pCreateInfo,
|
|
||||||
const VkAllocationCallbacks* pAllocator,
|
|
||||||
VkVideoSessionParametersKHR* pVideoSessionParameters);
|
|
||||||
|
|
||||||
VKAPI_ATTR VkResult VKAPI_CALL vkUpdateVideoSessionParametersKHR(
|
|
||||||
VkDevice device,
|
|
||||||
VkVideoSessionParametersKHR videoSessionParameters,
|
|
||||||
const VkVideoSessionParametersUpdateInfoKHR* pUpdateInfo);
|
|
||||||
|
|
||||||
VKAPI_ATTR void VKAPI_CALL vkDestroyVideoSessionParametersKHR(
|
|
||||||
VkDevice device,
|
|
||||||
VkVideoSessionParametersKHR videoSessionParameters,
|
|
||||||
const VkAllocationCallbacks* pAllocator);
|
|
||||||
|
|
||||||
VKAPI_ATTR void VKAPI_CALL vkCmdBeginVideoCodingKHR(
|
|
||||||
VkCommandBuffer commandBuffer,
|
|
||||||
const VkVideoBeginCodingInfoKHR* pBeginInfo);
|
|
||||||
|
|
||||||
VKAPI_ATTR void VKAPI_CALL vkCmdEndVideoCodingKHR(
|
|
||||||
VkCommandBuffer commandBuffer,
|
|
||||||
const VkVideoEndCodingInfoKHR* pEndCodingInfo);
|
|
||||||
|
|
||||||
VKAPI_ATTR void VKAPI_CALL vkCmdControlVideoCodingKHR(
|
|
||||||
VkCommandBuffer commandBuffer,
|
|
||||||
const VkVideoCodingControlInfoKHR* pCodingControlInfo);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_KHR_video_decode_queue 1
|
|
||||||
#define VK_KHR_VIDEO_DECODE_QUEUE_SPEC_VERSION 6
|
|
||||||
#define VK_KHR_VIDEO_DECODE_QUEUE_EXTENSION_NAME "VK_KHR_video_decode_queue"
|
|
||||||
|
|
||||||
typedef enum VkVideoDecodeCapabilityFlagBitsKHR {
|
|
||||||
VK_VIDEO_DECODE_CAPABILITY_DPB_AND_OUTPUT_COINCIDE_BIT_KHR = 0x00000001,
|
|
||||||
VK_VIDEO_DECODE_CAPABILITY_DPB_AND_OUTPUT_DISTINCT_BIT_KHR = 0x00000002,
|
|
||||||
VK_VIDEO_DECODE_CAPABILITY_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
|
||||||
} VkVideoDecodeCapabilityFlagBitsKHR;
|
|
||||||
typedef VkFlags VkVideoDecodeCapabilityFlagsKHR;
|
|
||||||
|
|
||||||
typedef enum VkVideoDecodeUsageFlagBitsKHR {
|
|
||||||
VK_VIDEO_DECODE_USAGE_DEFAULT_KHR = 0,
|
|
||||||
VK_VIDEO_DECODE_USAGE_TRANSCODING_BIT_KHR = 0x00000001,
|
|
||||||
VK_VIDEO_DECODE_USAGE_OFFLINE_BIT_KHR = 0x00000002,
|
|
||||||
VK_VIDEO_DECODE_USAGE_STREAMING_BIT_KHR = 0x00000004,
|
|
||||||
VK_VIDEO_DECODE_USAGE_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
|
||||||
} VkVideoDecodeUsageFlagBitsKHR;
|
|
||||||
typedef VkFlags VkVideoDecodeUsageFlagsKHR;
|
|
||||||
typedef VkFlags VkVideoDecodeFlagsKHR;
|
|
||||||
typedef struct VkVideoDecodeCapabilitiesKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
void* pNext;
|
|
||||||
VkVideoDecodeCapabilityFlagsKHR flags;
|
|
||||||
} VkVideoDecodeCapabilitiesKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoDecodeUsageInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
VkVideoDecodeUsageFlagsKHR videoUsageHints;
|
|
||||||
} VkVideoDecodeUsageInfoKHR;
|
|
||||||
|
|
||||||
typedef struct VkVideoDecodeInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
VkVideoDecodeFlagsKHR flags;
|
|
||||||
VkBuffer srcBuffer;
|
|
||||||
VkDeviceSize srcBufferOffset;
|
|
||||||
VkDeviceSize srcBufferRange;
|
|
||||||
VkVideoPictureResourceInfoKHR dstPictureResource;
|
|
||||||
const VkVideoReferenceSlotInfoKHR* pSetupReferenceSlot;
|
|
||||||
uint32_t referenceSlotCount;
|
|
||||||
const VkVideoReferenceSlotInfoKHR* pReferenceSlots;
|
|
||||||
} VkVideoDecodeInfoKHR;
|
|
||||||
|
|
||||||
typedef void (VKAPI_PTR *PFN_vkCmdDecodeVideoKHR)(VkCommandBuffer commandBuffer, const VkVideoDecodeInfoKHR* pDecodeInfo);
|
|
||||||
|
|
||||||
#ifndef VK_NO_PROTOTYPES
|
|
||||||
VKAPI_ATTR void VKAPI_CALL vkCmdDecodeVideoKHR(
|
|
||||||
VkCommandBuffer commandBuffer,
|
|
||||||
const VkVideoDecodeInfoKHR* pDecodeInfo);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_KHR_portability_subset 1
|
#define VK_KHR_portability_subset 1
|
||||||
#define VK_KHR_PORTABILITY_SUBSET_SPEC_VERSION 1
|
#define VK_KHR_PORTABILITY_SUBSET_SPEC_VERSION 1
|
||||||
#define VK_KHR_PORTABILITY_SUBSET_EXTENSION_NAME "VK_KHR_portability_subset"
|
#define VK_KHR_PORTABILITY_SUBSET_EXTENSION_NAME "VK_KHR_portability_subset"
|
||||||
@ -401,7 +51,7 @@ typedef struct VkPhysicalDevicePortabilitySubsetPropertiesKHR {
|
|||||||
|
|
||||||
|
|
||||||
#define VK_KHR_video_encode_queue 1
|
#define VK_KHR_video_encode_queue 1
|
||||||
#define VK_KHR_VIDEO_ENCODE_QUEUE_SPEC_VERSION 7
|
#define VK_KHR_VIDEO_ENCODE_QUEUE_SPEC_VERSION 8
|
||||||
#define VK_KHR_VIDEO_ENCODE_QUEUE_EXTENSION_NAME "VK_KHR_video_encode_queue"
|
#define VK_KHR_VIDEO_ENCODE_QUEUE_EXTENSION_NAME "VK_KHR_video_encode_queue"
|
||||||
|
|
||||||
typedef enum VkVideoEncodeTuningModeKHR {
|
typedef enum VkVideoEncodeTuningModeKHR {
|
||||||
@ -421,13 +71,21 @@ typedef enum VkVideoEncodeCapabilityFlagBitsKHR {
|
|||||||
typedef VkFlags VkVideoEncodeCapabilityFlagsKHR;
|
typedef VkFlags VkVideoEncodeCapabilityFlagsKHR;
|
||||||
|
|
||||||
typedef enum VkVideoEncodeRateControlModeFlagBitsKHR {
|
typedef enum VkVideoEncodeRateControlModeFlagBitsKHR {
|
||||||
VK_VIDEO_ENCODE_RATE_CONTROL_MODE_NONE_BIT_KHR = 0,
|
VK_VIDEO_ENCODE_RATE_CONTROL_MODE_DEFAULT_KHR = 0,
|
||||||
VK_VIDEO_ENCODE_RATE_CONTROL_MODE_CBR_BIT_KHR = 1,
|
VK_VIDEO_ENCODE_RATE_CONTROL_MODE_DISABLED_BIT_KHR = 0x00000001,
|
||||||
VK_VIDEO_ENCODE_RATE_CONTROL_MODE_VBR_BIT_KHR = 2,
|
VK_VIDEO_ENCODE_RATE_CONTROL_MODE_CBR_BIT_KHR = 0x00000002,
|
||||||
|
VK_VIDEO_ENCODE_RATE_CONTROL_MODE_VBR_BIT_KHR = 0x00000004,
|
||||||
VK_VIDEO_ENCODE_RATE_CONTROL_MODE_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
VK_VIDEO_ENCODE_RATE_CONTROL_MODE_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
||||||
} VkVideoEncodeRateControlModeFlagBitsKHR;
|
} VkVideoEncodeRateControlModeFlagBitsKHR;
|
||||||
typedef VkFlags VkVideoEncodeRateControlModeFlagsKHR;
|
typedef VkFlags VkVideoEncodeRateControlModeFlagsKHR;
|
||||||
|
|
||||||
|
typedef enum VkVideoEncodeFeedbackFlagBitsKHR {
|
||||||
|
VK_VIDEO_ENCODE_FEEDBACK_BITSTREAM_BUFFER_OFFSET_BIT_KHR = 0x00000001,
|
||||||
|
VK_VIDEO_ENCODE_FEEDBACK_BITSTREAM_BYTES_WRITTEN_BIT_KHR = 0x00000002,
|
||||||
|
VK_VIDEO_ENCODE_FEEDBACK_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
||||||
|
} VkVideoEncodeFeedbackFlagBitsKHR;
|
||||||
|
typedef VkFlags VkVideoEncodeFeedbackFlagsKHR;
|
||||||
|
|
||||||
typedef enum VkVideoEncodeUsageFlagBitsKHR {
|
typedef enum VkVideoEncodeUsageFlagBitsKHR {
|
||||||
VK_VIDEO_ENCODE_USAGE_DEFAULT_KHR = 0,
|
VK_VIDEO_ENCODE_USAGE_DEFAULT_KHR = 0,
|
||||||
VK_VIDEO_ENCODE_USAGE_TRANSCODING_BIT_KHR = 0x00000001,
|
VK_VIDEO_ENCODE_USAGE_TRANSCODING_BIT_KHR = 0x00000001,
|
||||||
@ -452,9 +110,9 @@ typedef struct VkVideoEncodeInfoKHR {
|
|||||||
const void* pNext;
|
const void* pNext;
|
||||||
VkVideoEncodeFlagsKHR flags;
|
VkVideoEncodeFlagsKHR flags;
|
||||||
uint32_t qualityLevel;
|
uint32_t qualityLevel;
|
||||||
VkBuffer dstBitstreamBuffer;
|
VkBuffer dstBuffer;
|
||||||
VkDeviceSize dstBitstreamBufferOffset;
|
VkDeviceSize dstBufferOffset;
|
||||||
VkDeviceSize dstBitstreamBufferMaxRange;
|
VkDeviceSize dstBufferRange;
|
||||||
VkVideoPictureResourceInfoKHR srcPictureResource;
|
VkVideoPictureResourceInfoKHR srcPictureResource;
|
||||||
const VkVideoReferenceSlotInfoKHR* pSetupReferenceSlot;
|
const VkVideoReferenceSlotInfoKHR* pSetupReferenceSlot;
|
||||||
uint32_t referenceSlotCount;
|
uint32_t referenceSlotCount;
|
||||||
@ -467,11 +125,18 @@ typedef struct VkVideoEncodeCapabilitiesKHR {
|
|||||||
void* pNext;
|
void* pNext;
|
||||||
VkVideoEncodeCapabilityFlagsKHR flags;
|
VkVideoEncodeCapabilityFlagsKHR flags;
|
||||||
VkVideoEncodeRateControlModeFlagsKHR rateControlModes;
|
VkVideoEncodeRateControlModeFlagsKHR rateControlModes;
|
||||||
uint8_t rateControlLayerCount;
|
uint32_t maxRateControlLayers;
|
||||||
uint8_t qualityLevelCount;
|
uint32_t maxQualityLevels;
|
||||||
VkExtent2D inputImageDataFillAlignment;
|
VkExtent2D inputImageDataFillAlignment;
|
||||||
|
VkVideoEncodeFeedbackFlagsKHR supportedEncodeFeedbackFlags;
|
||||||
} VkVideoEncodeCapabilitiesKHR;
|
} VkVideoEncodeCapabilitiesKHR;
|
||||||
|
|
||||||
|
typedef struct VkQueryPoolVideoEncodeFeedbackCreateInfoKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkVideoEncodeFeedbackFlagsKHR encodeFeedbackFlags;
|
||||||
|
} VkQueryPoolVideoEncodeFeedbackCreateInfoKHR;
|
||||||
|
|
||||||
typedef struct VkVideoEncodeUsageInfoKHR {
|
typedef struct VkVideoEncodeUsageInfoKHR {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
const void* pNext;
|
const void* pNext;
|
||||||
@ -483,8 +148,8 @@ typedef struct VkVideoEncodeUsageInfoKHR {
|
|||||||
typedef struct VkVideoEncodeRateControlLayerInfoKHR {
|
typedef struct VkVideoEncodeRateControlLayerInfoKHR {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
const void* pNext;
|
const void* pNext;
|
||||||
uint32_t averageBitrate;
|
uint64_t averageBitrate;
|
||||||
uint32_t maxBitrate;
|
uint64_t maxBitrate;
|
||||||
uint32_t frameRateNumerator;
|
uint32_t frameRateNumerator;
|
||||||
uint32_t frameRateDenominator;
|
uint32_t frameRateDenominator;
|
||||||
uint32_t virtualBufferSizeInMs;
|
uint32_t virtualBufferSizeInMs;
|
||||||
@ -496,8 +161,8 @@ typedef struct VkVideoEncodeRateControlInfoKHR {
|
|||||||
const void* pNext;
|
const void* pNext;
|
||||||
VkVideoEncodeRateControlFlagsKHR flags;
|
VkVideoEncodeRateControlFlagsKHR flags;
|
||||||
VkVideoEncodeRateControlModeFlagBitsKHR rateControlMode;
|
VkVideoEncodeRateControlModeFlagBitsKHR rateControlMode;
|
||||||
uint8_t layerCount;
|
uint32_t layerCount;
|
||||||
const VkVideoEncodeRateControlLayerInfoKHR* pLayerConfigs;
|
const VkVideoEncodeRateControlLayerInfoKHR* pLayers;
|
||||||
} VkVideoEncodeRateControlInfoKHR;
|
} VkVideoEncodeRateControlInfoKHR;
|
||||||
|
|
||||||
typedef void (VKAPI_PTR *PFN_vkCmdEncodeVideoKHR)(VkCommandBuffer commandBuffer, const VkVideoEncodeInfoKHR* pEncodeInfo);
|
typedef void (VKAPI_PTR *PFN_vkCmdEncodeVideoKHR)(VkCommandBuffer commandBuffer, const VkVideoEncodeInfoKHR* pEncodeInfo);
|
||||||
@ -512,7 +177,7 @@ VKAPI_ATTR void VKAPI_CALL vkCmdEncodeVideoKHR(
|
|||||||
#define VK_EXT_video_encode_h264 1
|
#define VK_EXT_video_encode_h264 1
|
||||||
#include "vk_video/vulkan_video_codec_h264std.h"
|
#include "vk_video/vulkan_video_codec_h264std.h"
|
||||||
#include "vk_video/vulkan_video_codec_h264std_encode.h"
|
#include "vk_video/vulkan_video_codec_h264std_encode.h"
|
||||||
#define VK_EXT_VIDEO_ENCODE_H264_SPEC_VERSION 9
|
#define VK_EXT_VIDEO_ENCODE_H264_SPEC_VERSION 10
|
||||||
#define VK_EXT_VIDEO_ENCODE_H264_EXTENSION_NAME "VK_EXT_video_encode_h264"
|
#define VK_EXT_VIDEO_ENCODE_H264_EXTENSION_NAME "VK_EXT_video_encode_h264"
|
||||||
|
|
||||||
typedef enum VkVideoEncodeH264RateControlStructureEXT {
|
typedef enum VkVideoEncodeH264RateControlStructureEXT {
|
||||||
@ -548,34 +213,17 @@ typedef enum VkVideoEncodeH264CapabilityFlagBitsEXT {
|
|||||||
VK_VIDEO_ENCODE_H264_CAPABILITY_ROW_UNALIGNED_SLICE_BIT_EXT = 0x00400000,
|
VK_VIDEO_ENCODE_H264_CAPABILITY_ROW_UNALIGNED_SLICE_BIT_EXT = 0x00400000,
|
||||||
VK_VIDEO_ENCODE_H264_CAPABILITY_DIFFERENT_SLICE_TYPE_BIT_EXT = 0x00800000,
|
VK_VIDEO_ENCODE_H264_CAPABILITY_DIFFERENT_SLICE_TYPE_BIT_EXT = 0x00800000,
|
||||||
VK_VIDEO_ENCODE_H264_CAPABILITY_B_FRAME_IN_L1_LIST_BIT_EXT = 0x01000000,
|
VK_VIDEO_ENCODE_H264_CAPABILITY_B_FRAME_IN_L1_LIST_BIT_EXT = 0x01000000,
|
||||||
|
VK_VIDEO_ENCODE_H264_CAPABILITY_DIFFERENT_REFERENCE_FINAL_LISTS_BIT_EXT = 0x02000000,
|
||||||
VK_VIDEO_ENCODE_H264_CAPABILITY_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
VK_VIDEO_ENCODE_H264_CAPABILITY_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
||||||
} VkVideoEncodeH264CapabilityFlagBitsEXT;
|
} VkVideoEncodeH264CapabilityFlagBitsEXT;
|
||||||
typedef VkFlags VkVideoEncodeH264CapabilityFlagsEXT;
|
typedef VkFlags VkVideoEncodeH264CapabilityFlagsEXT;
|
||||||
|
|
||||||
typedef enum VkVideoEncodeH264InputModeFlagBitsEXT {
|
|
||||||
VK_VIDEO_ENCODE_H264_INPUT_MODE_FRAME_BIT_EXT = 0x00000001,
|
|
||||||
VK_VIDEO_ENCODE_H264_INPUT_MODE_SLICE_BIT_EXT = 0x00000002,
|
|
||||||
VK_VIDEO_ENCODE_H264_INPUT_MODE_NON_VCL_BIT_EXT = 0x00000004,
|
|
||||||
VK_VIDEO_ENCODE_H264_INPUT_MODE_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
|
||||||
} VkVideoEncodeH264InputModeFlagBitsEXT;
|
|
||||||
typedef VkFlags VkVideoEncodeH264InputModeFlagsEXT;
|
|
||||||
|
|
||||||
typedef enum VkVideoEncodeH264OutputModeFlagBitsEXT {
|
|
||||||
VK_VIDEO_ENCODE_H264_OUTPUT_MODE_FRAME_BIT_EXT = 0x00000001,
|
|
||||||
VK_VIDEO_ENCODE_H264_OUTPUT_MODE_SLICE_BIT_EXT = 0x00000002,
|
|
||||||
VK_VIDEO_ENCODE_H264_OUTPUT_MODE_NON_VCL_BIT_EXT = 0x00000004,
|
|
||||||
VK_VIDEO_ENCODE_H264_OUTPUT_MODE_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
|
||||||
} VkVideoEncodeH264OutputModeFlagBitsEXT;
|
|
||||||
typedef VkFlags VkVideoEncodeH264OutputModeFlagsEXT;
|
|
||||||
typedef struct VkVideoEncodeH264CapabilitiesEXT {
|
typedef struct VkVideoEncodeH264CapabilitiesEXT {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
void* pNext;
|
void* pNext;
|
||||||
VkVideoEncodeH264CapabilityFlagsEXT flags;
|
VkVideoEncodeH264CapabilityFlagsEXT flags;
|
||||||
VkVideoEncodeH264InputModeFlagsEXT inputModeFlags;
|
uint32_t maxPPictureL0ReferenceCount;
|
||||||
VkVideoEncodeH264OutputModeFlagsEXT outputModeFlags;
|
uint32_t maxBPictureL0ReferenceCount;
|
||||||
uint8_t maxPPictureL0ReferenceCount;
|
uint32_t maxL1ReferenceCount;
|
||||||
uint8_t maxBPictureL0ReferenceCount;
|
|
||||||
uint8_t maxL1ReferenceCount;
|
|
||||||
VkBool32 motionVectorsOverPicBoundariesFlag;
|
VkBool32 motionVectorsOverPicBoundariesFlag;
|
||||||
uint32_t maxBytesPerPicDenom;
|
uint32_t maxBytesPerPicDenom;
|
||||||
uint32_t maxBitsPerMbDenom;
|
uint32_t maxBitsPerMbDenom;
|
||||||
@ -600,48 +248,28 @@ typedef struct VkVideoEncodeH264SessionParametersCreateInfoEXT {
|
|||||||
const VkVideoEncodeH264SessionParametersAddInfoEXT* pParametersAddInfo;
|
const VkVideoEncodeH264SessionParametersAddInfoEXT* pParametersAddInfo;
|
||||||
} VkVideoEncodeH264SessionParametersCreateInfoEXT;
|
} VkVideoEncodeH264SessionParametersCreateInfoEXT;
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH264DpbSlotInfoEXT {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
int8_t slotIndex;
|
|
||||||
const StdVideoEncodeH264ReferenceInfo* pStdReferenceInfo;
|
|
||||||
} VkVideoEncodeH264DpbSlotInfoEXT;
|
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH264ReferenceListsInfoEXT {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
uint8_t referenceList0EntryCount;
|
|
||||||
const VkVideoEncodeH264DpbSlotInfoEXT* pReferenceList0Entries;
|
|
||||||
uint8_t referenceList1EntryCount;
|
|
||||||
const VkVideoEncodeH264DpbSlotInfoEXT* pReferenceList1Entries;
|
|
||||||
const StdVideoEncodeH264RefMemMgmtCtrlOperations* pMemMgmtCtrlOperations;
|
|
||||||
} VkVideoEncodeH264ReferenceListsInfoEXT;
|
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH264NaluSliceInfoEXT {
|
typedef struct VkVideoEncodeH264NaluSliceInfoEXT {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
const void* pNext;
|
const void* pNext;
|
||||||
uint32_t mbCount;
|
uint32_t mbCount;
|
||||||
const VkVideoEncodeH264ReferenceListsInfoEXT* pReferenceFinalLists;
|
const StdVideoEncodeH264ReferenceListsInfo* pStdReferenceFinalLists;
|
||||||
const StdVideoEncodeH264SliceHeader* pSliceHeaderStd;
|
const StdVideoEncodeH264SliceHeader* pStdSliceHeader;
|
||||||
} VkVideoEncodeH264NaluSliceInfoEXT;
|
} VkVideoEncodeH264NaluSliceInfoEXT;
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH264VclFrameInfoEXT {
|
typedef struct VkVideoEncodeH264VclFrameInfoEXT {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
const void* pNext;
|
const void* pNext;
|
||||||
const VkVideoEncodeH264ReferenceListsInfoEXT* pReferenceFinalLists;
|
const StdVideoEncodeH264ReferenceListsInfo* pStdReferenceFinalLists;
|
||||||
uint32_t naluSliceEntryCount;
|
uint32_t naluSliceEntryCount;
|
||||||
const VkVideoEncodeH264NaluSliceInfoEXT* pNaluSliceEntries;
|
const VkVideoEncodeH264NaluSliceInfoEXT* pNaluSliceEntries;
|
||||||
const StdVideoEncodeH264PictureInfo* pCurrentPictureInfo;
|
const StdVideoEncodeH264PictureInfo* pStdPictureInfo;
|
||||||
} VkVideoEncodeH264VclFrameInfoEXT;
|
} VkVideoEncodeH264VclFrameInfoEXT;
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH264EmitPictureParametersInfoEXT {
|
typedef struct VkVideoEncodeH264DpbSlotInfoEXT {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
const void* pNext;
|
const void* pNext;
|
||||||
uint8_t spsId;
|
const StdVideoEncodeH264ReferenceInfo* pStdReferenceInfo;
|
||||||
VkBool32 emitSpsEnable;
|
} VkVideoEncodeH264DpbSlotInfoEXT;
|
||||||
uint32_t ppsIdEntryCount;
|
|
||||||
const uint8_t* ppsIdEntries;
|
|
||||||
} VkVideoEncodeH264EmitPictureParametersInfoEXT;
|
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH264ProfileInfoEXT {
|
typedef struct VkVideoEncodeH264ProfileInfoEXT {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
@ -656,7 +284,7 @@ typedef struct VkVideoEncodeH264RateControlInfoEXT {
|
|||||||
uint32_t idrPeriod;
|
uint32_t idrPeriod;
|
||||||
uint32_t consecutiveBFrameCount;
|
uint32_t consecutiveBFrameCount;
|
||||||
VkVideoEncodeH264RateControlStructureEXT rateControlStructure;
|
VkVideoEncodeH264RateControlStructureEXT rateControlStructure;
|
||||||
uint8_t temporalLayerCount;
|
uint32_t temporalLayerCount;
|
||||||
} VkVideoEncodeH264RateControlInfoEXT;
|
} VkVideoEncodeH264RateControlInfoEXT;
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH264QpEXT {
|
typedef struct VkVideoEncodeH264QpEXT {
|
||||||
@ -674,7 +302,7 @@ typedef struct VkVideoEncodeH264FrameSizeEXT {
|
|||||||
typedef struct VkVideoEncodeH264RateControlLayerInfoEXT {
|
typedef struct VkVideoEncodeH264RateControlLayerInfoEXT {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
const void* pNext;
|
const void* pNext;
|
||||||
uint8_t temporalLayerId;
|
uint32_t temporalLayerId;
|
||||||
VkBool32 useInitialRcQp;
|
VkBool32 useInitialRcQp;
|
||||||
VkVideoEncodeH264QpEXT initialRcQp;
|
VkVideoEncodeH264QpEXT initialRcQp;
|
||||||
VkBool32 useMinQp;
|
VkBool32 useMinQp;
|
||||||
@ -690,7 +318,7 @@ typedef struct VkVideoEncodeH264RateControlLayerInfoEXT {
|
|||||||
#define VK_EXT_video_encode_h265 1
|
#define VK_EXT_video_encode_h265 1
|
||||||
#include "vk_video/vulkan_video_codec_h265std.h"
|
#include "vk_video/vulkan_video_codec_h265std.h"
|
||||||
#include "vk_video/vulkan_video_codec_h265std_encode.h"
|
#include "vk_video/vulkan_video_codec_h265std_encode.h"
|
||||||
#define VK_EXT_VIDEO_ENCODE_H265_SPEC_VERSION 9
|
#define VK_EXT_VIDEO_ENCODE_H265_SPEC_VERSION 10
|
||||||
#define VK_EXT_VIDEO_ENCODE_H265_EXTENSION_NAME "VK_EXT_video_encode_h265"
|
#define VK_EXT_VIDEO_ENCODE_H265_EXTENSION_NAME "VK_EXT_video_encode_h265"
|
||||||
|
|
||||||
typedef enum VkVideoEncodeH265RateControlStructureEXT {
|
typedef enum VkVideoEncodeH265RateControlStructureEXT {
|
||||||
@ -727,26 +355,11 @@ typedef enum VkVideoEncodeH265CapabilityFlagBitsEXT {
|
|||||||
VK_VIDEO_ENCODE_H265_CAPABILITY_DEPENDENT_SLICE_SEGMENT_BIT_EXT = 0x00800000,
|
VK_VIDEO_ENCODE_H265_CAPABILITY_DEPENDENT_SLICE_SEGMENT_BIT_EXT = 0x00800000,
|
||||||
VK_VIDEO_ENCODE_H265_CAPABILITY_DIFFERENT_SLICE_TYPE_BIT_EXT = 0x01000000,
|
VK_VIDEO_ENCODE_H265_CAPABILITY_DIFFERENT_SLICE_TYPE_BIT_EXT = 0x01000000,
|
||||||
VK_VIDEO_ENCODE_H265_CAPABILITY_B_FRAME_IN_L1_LIST_BIT_EXT = 0x02000000,
|
VK_VIDEO_ENCODE_H265_CAPABILITY_B_FRAME_IN_L1_LIST_BIT_EXT = 0x02000000,
|
||||||
|
VK_VIDEO_ENCODE_H265_CAPABILITY_DIFFERENT_REFERENCE_FINAL_LISTS_BIT_EXT = 0x04000000,
|
||||||
VK_VIDEO_ENCODE_H265_CAPABILITY_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
VK_VIDEO_ENCODE_H265_CAPABILITY_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
||||||
} VkVideoEncodeH265CapabilityFlagBitsEXT;
|
} VkVideoEncodeH265CapabilityFlagBitsEXT;
|
||||||
typedef VkFlags VkVideoEncodeH265CapabilityFlagsEXT;
|
typedef VkFlags VkVideoEncodeH265CapabilityFlagsEXT;
|
||||||
|
|
||||||
typedef enum VkVideoEncodeH265InputModeFlagBitsEXT {
|
|
||||||
VK_VIDEO_ENCODE_H265_INPUT_MODE_FRAME_BIT_EXT = 0x00000001,
|
|
||||||
VK_VIDEO_ENCODE_H265_INPUT_MODE_SLICE_SEGMENT_BIT_EXT = 0x00000002,
|
|
||||||
VK_VIDEO_ENCODE_H265_INPUT_MODE_NON_VCL_BIT_EXT = 0x00000004,
|
|
||||||
VK_VIDEO_ENCODE_H265_INPUT_MODE_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
|
||||||
} VkVideoEncodeH265InputModeFlagBitsEXT;
|
|
||||||
typedef VkFlags VkVideoEncodeH265InputModeFlagsEXT;
|
|
||||||
|
|
||||||
typedef enum VkVideoEncodeH265OutputModeFlagBitsEXT {
|
|
||||||
VK_VIDEO_ENCODE_H265_OUTPUT_MODE_FRAME_BIT_EXT = 0x00000001,
|
|
||||||
VK_VIDEO_ENCODE_H265_OUTPUT_MODE_SLICE_SEGMENT_BIT_EXT = 0x00000002,
|
|
||||||
VK_VIDEO_ENCODE_H265_OUTPUT_MODE_NON_VCL_BIT_EXT = 0x00000004,
|
|
||||||
VK_VIDEO_ENCODE_H265_OUTPUT_MODE_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
|
||||||
} VkVideoEncodeH265OutputModeFlagBitsEXT;
|
|
||||||
typedef VkFlags VkVideoEncodeH265OutputModeFlagsEXT;
|
|
||||||
|
|
||||||
typedef enum VkVideoEncodeH265CtbSizeFlagBitsEXT {
|
typedef enum VkVideoEncodeH265CtbSizeFlagBitsEXT {
|
||||||
VK_VIDEO_ENCODE_H265_CTB_SIZE_16_BIT_EXT = 0x00000001,
|
VK_VIDEO_ENCODE_H265_CTB_SIZE_16_BIT_EXT = 0x00000001,
|
||||||
VK_VIDEO_ENCODE_H265_CTB_SIZE_32_BIT_EXT = 0x00000002,
|
VK_VIDEO_ENCODE_H265_CTB_SIZE_32_BIT_EXT = 0x00000002,
|
||||||
@ -767,25 +380,23 @@ typedef struct VkVideoEncodeH265CapabilitiesEXT {
|
|||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
void* pNext;
|
void* pNext;
|
||||||
VkVideoEncodeH265CapabilityFlagsEXT flags;
|
VkVideoEncodeH265CapabilityFlagsEXT flags;
|
||||||
VkVideoEncodeH265InputModeFlagsEXT inputModeFlags;
|
|
||||||
VkVideoEncodeH265OutputModeFlagsEXT outputModeFlags;
|
|
||||||
VkVideoEncodeH265CtbSizeFlagsEXT ctbSizes;
|
VkVideoEncodeH265CtbSizeFlagsEXT ctbSizes;
|
||||||
VkVideoEncodeH265TransformBlockSizeFlagsEXT transformBlockSizes;
|
VkVideoEncodeH265TransformBlockSizeFlagsEXT transformBlockSizes;
|
||||||
uint8_t maxPPictureL0ReferenceCount;
|
uint32_t maxPPictureL0ReferenceCount;
|
||||||
uint8_t maxBPictureL0ReferenceCount;
|
uint32_t maxBPictureL0ReferenceCount;
|
||||||
uint8_t maxL1ReferenceCount;
|
uint32_t maxL1ReferenceCount;
|
||||||
uint8_t maxSubLayersCount;
|
uint32_t maxSubLayersCount;
|
||||||
uint8_t minLog2MinLumaCodingBlockSizeMinus3;
|
uint32_t minLog2MinLumaCodingBlockSizeMinus3;
|
||||||
uint8_t maxLog2MinLumaCodingBlockSizeMinus3;
|
uint32_t maxLog2MinLumaCodingBlockSizeMinus3;
|
||||||
uint8_t minLog2MinLumaTransformBlockSizeMinus2;
|
uint32_t minLog2MinLumaTransformBlockSizeMinus2;
|
||||||
uint8_t maxLog2MinLumaTransformBlockSizeMinus2;
|
uint32_t maxLog2MinLumaTransformBlockSizeMinus2;
|
||||||
uint8_t minMaxTransformHierarchyDepthInter;
|
uint32_t minMaxTransformHierarchyDepthInter;
|
||||||
uint8_t maxMaxTransformHierarchyDepthInter;
|
uint32_t maxMaxTransformHierarchyDepthInter;
|
||||||
uint8_t minMaxTransformHierarchyDepthIntra;
|
uint32_t minMaxTransformHierarchyDepthIntra;
|
||||||
uint8_t maxMaxTransformHierarchyDepthIntra;
|
uint32_t maxMaxTransformHierarchyDepthIntra;
|
||||||
uint8_t maxDiffCuQpDeltaDepth;
|
uint32_t maxDiffCuQpDeltaDepth;
|
||||||
uint8_t minMaxNumMergeCand;
|
uint32_t minMaxNumMergeCand;
|
||||||
uint8_t maxMaxNumMergeCand;
|
uint32_t maxMaxNumMergeCand;
|
||||||
} VkVideoEncodeH265CapabilitiesEXT;
|
} VkVideoEncodeH265CapabilitiesEXT;
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH265SessionParametersAddInfoEXT {
|
typedef struct VkVideoEncodeH265SessionParametersAddInfoEXT {
|
||||||
@ -808,50 +419,28 @@ typedef struct VkVideoEncodeH265SessionParametersCreateInfoEXT {
|
|||||||
const VkVideoEncodeH265SessionParametersAddInfoEXT* pParametersAddInfo;
|
const VkVideoEncodeH265SessionParametersAddInfoEXT* pParametersAddInfo;
|
||||||
} VkVideoEncodeH265SessionParametersCreateInfoEXT;
|
} VkVideoEncodeH265SessionParametersCreateInfoEXT;
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH265DpbSlotInfoEXT {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
int8_t slotIndex;
|
|
||||||
const StdVideoEncodeH265ReferenceInfo* pStdReferenceInfo;
|
|
||||||
} VkVideoEncodeH265DpbSlotInfoEXT;
|
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH265ReferenceListsInfoEXT {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
uint8_t referenceList0EntryCount;
|
|
||||||
const VkVideoEncodeH265DpbSlotInfoEXT* pReferenceList0Entries;
|
|
||||||
uint8_t referenceList1EntryCount;
|
|
||||||
const VkVideoEncodeH265DpbSlotInfoEXT* pReferenceList1Entries;
|
|
||||||
const StdVideoEncodeH265ReferenceModifications* pReferenceModifications;
|
|
||||||
} VkVideoEncodeH265ReferenceListsInfoEXT;
|
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH265NaluSliceSegmentInfoEXT {
|
typedef struct VkVideoEncodeH265NaluSliceSegmentInfoEXT {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
const void* pNext;
|
const void* pNext;
|
||||||
uint32_t ctbCount;
|
uint32_t ctbCount;
|
||||||
const VkVideoEncodeH265ReferenceListsInfoEXT* pReferenceFinalLists;
|
const StdVideoEncodeH265ReferenceListsInfo* pStdReferenceFinalLists;
|
||||||
const StdVideoEncodeH265SliceSegmentHeader* pSliceSegmentHeaderStd;
|
const StdVideoEncodeH265SliceSegmentHeader* pStdSliceSegmentHeader;
|
||||||
} VkVideoEncodeH265NaluSliceSegmentInfoEXT;
|
} VkVideoEncodeH265NaluSliceSegmentInfoEXT;
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH265VclFrameInfoEXT {
|
typedef struct VkVideoEncodeH265VclFrameInfoEXT {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
const void* pNext;
|
const void* pNext;
|
||||||
const VkVideoEncodeH265ReferenceListsInfoEXT* pReferenceFinalLists;
|
const StdVideoEncodeH265ReferenceListsInfo* pStdReferenceFinalLists;
|
||||||
uint32_t naluSliceSegmentEntryCount;
|
uint32_t naluSliceSegmentEntryCount;
|
||||||
const VkVideoEncodeH265NaluSliceSegmentInfoEXT* pNaluSliceSegmentEntries;
|
const VkVideoEncodeH265NaluSliceSegmentInfoEXT* pNaluSliceSegmentEntries;
|
||||||
const StdVideoEncodeH265PictureInfo* pCurrentPictureInfo;
|
const StdVideoEncodeH265PictureInfo* pStdPictureInfo;
|
||||||
} VkVideoEncodeH265VclFrameInfoEXT;
|
} VkVideoEncodeH265VclFrameInfoEXT;
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH265EmitPictureParametersInfoEXT {
|
typedef struct VkVideoEncodeH265DpbSlotInfoEXT {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
const void* pNext;
|
const void* pNext;
|
||||||
uint8_t vpsId;
|
const StdVideoEncodeH265ReferenceInfo* pStdReferenceInfo;
|
||||||
uint8_t spsId;
|
} VkVideoEncodeH265DpbSlotInfoEXT;
|
||||||
VkBool32 emitVpsEnable;
|
|
||||||
VkBool32 emitSpsEnable;
|
|
||||||
uint32_t ppsIdEntryCount;
|
|
||||||
const uint8_t* ppsIdEntries;
|
|
||||||
} VkVideoEncodeH265EmitPictureParametersInfoEXT;
|
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH265ProfileInfoEXT {
|
typedef struct VkVideoEncodeH265ProfileInfoEXT {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
@ -866,7 +455,7 @@ typedef struct VkVideoEncodeH265RateControlInfoEXT {
|
|||||||
uint32_t idrPeriod;
|
uint32_t idrPeriod;
|
||||||
uint32_t consecutiveBFrameCount;
|
uint32_t consecutiveBFrameCount;
|
||||||
VkVideoEncodeH265RateControlStructureEXT rateControlStructure;
|
VkVideoEncodeH265RateControlStructureEXT rateControlStructure;
|
||||||
uint8_t subLayerCount;
|
uint32_t subLayerCount;
|
||||||
} VkVideoEncodeH265RateControlInfoEXT;
|
} VkVideoEncodeH265RateControlInfoEXT;
|
||||||
|
|
||||||
typedef struct VkVideoEncodeH265QpEXT {
|
typedef struct VkVideoEncodeH265QpEXT {
|
||||||
@ -884,7 +473,7 @@ typedef struct VkVideoEncodeH265FrameSizeEXT {
|
|||||||
typedef struct VkVideoEncodeH265RateControlLayerInfoEXT {
|
typedef struct VkVideoEncodeH265RateControlLayerInfoEXT {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
const void* pNext;
|
const void* pNext;
|
||||||
uint8_t temporalId;
|
uint32_t temporalId;
|
||||||
VkBool32 useInitialRcQp;
|
VkBool32 useInitialRcQp;
|
||||||
VkVideoEncodeH265QpEXT initialRcQp;
|
VkVideoEncodeH265QpEXT initialRcQp;
|
||||||
VkBool32 useMinQp;
|
VkBool32 useMinQp;
|
||||||
@ -897,114 +486,48 @@ typedef struct VkVideoEncodeH265RateControlLayerInfoEXT {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_EXT_video_decode_h264 1
|
#define VK_NV_displacement_micromap 1
|
||||||
#include "vk_video/vulkan_video_codec_h264std_decode.h"
|
#define VK_NV_DISPLACEMENT_MICROMAP_SPEC_VERSION 1
|
||||||
#define VK_EXT_VIDEO_DECODE_H264_SPEC_VERSION 7
|
#define VK_NV_DISPLACEMENT_MICROMAP_EXTENSION_NAME "VK_NV_displacement_micromap"
|
||||||
#define VK_EXT_VIDEO_DECODE_H264_EXTENSION_NAME "VK_EXT_video_decode_h264"
|
|
||||||
|
|
||||||
typedef enum VkVideoDecodeH264PictureLayoutFlagBitsEXT {
|
typedef enum VkDisplacementMicromapFormatNV {
|
||||||
VK_VIDEO_DECODE_H264_PICTURE_LAYOUT_PROGRESSIVE_EXT = 0,
|
VK_DISPLACEMENT_MICROMAP_FORMAT_64_TRIANGLES_64_BYTES_NV = 1,
|
||||||
VK_VIDEO_DECODE_H264_PICTURE_LAYOUT_INTERLACED_INTERLEAVED_LINES_BIT_EXT = 0x00000001,
|
VK_DISPLACEMENT_MICROMAP_FORMAT_256_TRIANGLES_128_BYTES_NV = 2,
|
||||||
VK_VIDEO_DECODE_H264_PICTURE_LAYOUT_INTERLACED_SEPARATE_PLANES_BIT_EXT = 0x00000002,
|
VK_DISPLACEMENT_MICROMAP_FORMAT_1024_TRIANGLES_128_BYTES_NV = 3,
|
||||||
VK_VIDEO_DECODE_H264_PICTURE_LAYOUT_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
VK_DISPLACEMENT_MICROMAP_FORMAT_MAX_ENUM_NV = 0x7FFFFFFF
|
||||||
} VkVideoDecodeH264PictureLayoutFlagBitsEXT;
|
} VkDisplacementMicromapFormatNV;
|
||||||
typedef VkFlags VkVideoDecodeH264PictureLayoutFlagsEXT;
|
typedef struct VkPhysicalDeviceDisplacementMicromapFeaturesNV {
|
||||||
typedef struct VkVideoDecodeH264ProfileInfoEXT {
|
VkStructureType sType;
|
||||||
VkStructureType sType;
|
void* pNext;
|
||||||
const void* pNext;
|
VkBool32 displacementMicromap;
|
||||||
StdVideoH264ProfileIdc stdProfileIdc;
|
} VkPhysicalDeviceDisplacementMicromapFeaturesNV;
|
||||||
VkVideoDecodeH264PictureLayoutFlagBitsEXT pictureLayout;
|
|
||||||
} VkVideoDecodeH264ProfileInfoEXT;
|
|
||||||
|
|
||||||
typedef struct VkVideoDecodeH264CapabilitiesEXT {
|
typedef struct VkPhysicalDeviceDisplacementMicromapPropertiesNV {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
void* pNext;
|
void* pNext;
|
||||||
StdVideoH264LevelIdc maxLevelIdc;
|
uint32_t maxDisplacementMicromapSubdivisionLevel;
|
||||||
VkOffset2D fieldOffsetGranularity;
|
} VkPhysicalDeviceDisplacementMicromapPropertiesNV;
|
||||||
} VkVideoDecodeH264CapabilitiesEXT;
|
|
||||||
|
|
||||||
typedef struct VkVideoDecodeH264SessionParametersAddInfoEXT {
|
typedef struct VkAccelerationStructureTrianglesDisplacementMicromapNV {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
const void* pNext;
|
void* pNext;
|
||||||
uint32_t stdSPSCount;
|
VkFormat displacementBiasAndScaleFormat;
|
||||||
const StdVideoH264SequenceParameterSet* pStdSPSs;
|
VkFormat displacementVectorFormat;
|
||||||
uint32_t stdPPSCount;
|
VkDeviceOrHostAddressConstKHR displacementBiasAndScaleBuffer;
|
||||||
const StdVideoH264PictureParameterSet* pStdPPSs;
|
VkDeviceSize displacementBiasAndScaleStride;
|
||||||
} VkVideoDecodeH264SessionParametersAddInfoEXT;
|
VkDeviceOrHostAddressConstKHR displacementVectorBuffer;
|
||||||
|
VkDeviceSize displacementVectorStride;
|
||||||
typedef struct VkVideoDecodeH264SessionParametersCreateInfoEXT {
|
VkDeviceOrHostAddressConstKHR displacedMicromapPrimitiveFlags;
|
||||||
VkStructureType sType;
|
VkDeviceSize displacedMicromapPrimitiveFlagsStride;
|
||||||
const void* pNext;
|
VkIndexType indexType;
|
||||||
uint32_t maxStdSPSCount;
|
VkDeviceOrHostAddressConstKHR indexBuffer;
|
||||||
uint32_t maxStdPPSCount;
|
VkDeviceSize indexStride;
|
||||||
const VkVideoDecodeH264SessionParametersAddInfoEXT* pParametersAddInfo;
|
uint32_t baseTriangle;
|
||||||
} VkVideoDecodeH264SessionParametersCreateInfoEXT;
|
uint32_t usageCountsCount;
|
||||||
|
const VkMicromapUsageEXT* pUsageCounts;
|
||||||
typedef struct VkVideoDecodeH264PictureInfoEXT {
|
const VkMicromapUsageEXT* const* ppUsageCounts;
|
||||||
VkStructureType sType;
|
VkMicromapEXT micromap;
|
||||||
const void* pNext;
|
} VkAccelerationStructureTrianglesDisplacementMicromapNV;
|
||||||
const StdVideoDecodeH264PictureInfo* pStdPictureInfo;
|
|
||||||
uint32_t sliceCount;
|
|
||||||
const uint32_t* pSliceOffsets;
|
|
||||||
} VkVideoDecodeH264PictureInfoEXT;
|
|
||||||
|
|
||||||
typedef struct VkVideoDecodeH264DpbSlotInfoEXT {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
const StdVideoDecodeH264ReferenceInfo* pStdReferenceInfo;
|
|
||||||
} VkVideoDecodeH264DpbSlotInfoEXT;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_EXT_video_decode_h265 1
|
|
||||||
#include "vk_video/vulkan_video_codec_h265std_decode.h"
|
|
||||||
#define VK_EXT_VIDEO_DECODE_H265_SPEC_VERSION 5
|
|
||||||
#define VK_EXT_VIDEO_DECODE_H265_EXTENSION_NAME "VK_EXT_video_decode_h265"
|
|
||||||
typedef struct VkVideoDecodeH265ProfileInfoEXT {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
StdVideoH265ProfileIdc stdProfileIdc;
|
|
||||||
} VkVideoDecodeH265ProfileInfoEXT;
|
|
||||||
|
|
||||||
typedef struct VkVideoDecodeH265CapabilitiesEXT {
|
|
||||||
VkStructureType sType;
|
|
||||||
void* pNext;
|
|
||||||
StdVideoH265LevelIdc maxLevelIdc;
|
|
||||||
} VkVideoDecodeH265CapabilitiesEXT;
|
|
||||||
|
|
||||||
typedef struct VkVideoDecodeH265SessionParametersAddInfoEXT {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
uint32_t stdVPSCount;
|
|
||||||
const StdVideoH265VideoParameterSet* pStdVPSs;
|
|
||||||
uint32_t stdSPSCount;
|
|
||||||
const StdVideoH265SequenceParameterSet* pStdSPSs;
|
|
||||||
uint32_t stdPPSCount;
|
|
||||||
const StdVideoH265PictureParameterSet* pStdPPSs;
|
|
||||||
} VkVideoDecodeH265SessionParametersAddInfoEXT;
|
|
||||||
|
|
||||||
typedef struct VkVideoDecodeH265SessionParametersCreateInfoEXT {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
uint32_t maxStdVPSCount;
|
|
||||||
uint32_t maxStdSPSCount;
|
|
||||||
uint32_t maxStdPPSCount;
|
|
||||||
const VkVideoDecodeH265SessionParametersAddInfoEXT* pParametersAddInfo;
|
|
||||||
} VkVideoDecodeH265SessionParametersCreateInfoEXT;
|
|
||||||
|
|
||||||
typedef struct VkVideoDecodeH265PictureInfoEXT {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
StdVideoDecodeH265PictureInfo* pStdPictureInfo;
|
|
||||||
uint32_t sliceCount;
|
|
||||||
const uint32_t* pSliceOffsets;
|
|
||||||
} VkVideoDecodeH265PictureInfoEXT;
|
|
||||||
|
|
||||||
typedef struct VkVideoDecodeH265DpbSlotInfoEXT {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
const StdVideoDecodeH265ReferenceInfo* pStdReferenceInfo;
|
|
||||||
} VkVideoDecodeH265DpbSlotInfoEXT;
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_DIRECTFB_H_ 1
|
#define VULKAN_DIRECTFB_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
File diff suppressed because it is too large
Load Diff
1586
include/vulkan/vulkan_extension_inspection.hpp
Normal file
1586
include/vulkan/vulkan_extension_inspection.hpp
Normal file
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_FUCHSIA_H_ 1
|
#define VULKAN_FUCHSIA_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_GGP_H_ 1
|
#define VULKAN_GGP_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_IOS_H_ 1
|
#define VULKAN_IOS_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_MACOS_H_ 1
|
#define VULKAN_MACOS_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_METAL_H_ 1
|
#define VULKAN_METAL_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_OHOS_H_ 1
|
#define VULKAN_OHOS_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_SCREEN_H_ 1
|
#define VULKAN_SCREEN_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
// Copyright 2015-2022 The Khronos Group Inc.
|
// Copyright 2015-2023 The Khronos Group Inc.
|
||||||
//
|
//
|
||||||
// SPDX-License-Identifier: Apache-2.0 OR MIT
|
// SPDX-License-Identifier: Apache-2.0 OR MIT
|
||||||
//
|
//
|
||||||
|
|
||||||
// This header is generated from the Khronos Vulkan XML API Registry.
|
// This header is generated from the Khronos Vulkan XML API Registry.
|
||||||
|
|
||||||
#ifndef VULKAN_STRUCTS_HPP
|
#ifndef VULKAN_STATIC_ASSERTIONS_HPP
|
||||||
#define VULKAN_STRUCTS_HPP
|
#define VULKAN_STATIC_ASSERTIONS_HPP
|
||||||
|
|
||||||
#include <vulkan/vulkan.hpp>
|
#include <vulkan/vulkan.hpp>
|
||||||
|
|
||||||
@ -2000,7 +2000,6 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::DebugMar
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::DebugMarkerMarkerInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::DebugMarkerMarkerInfoEXT>::value,
|
||||||
"DebugMarkerMarkerInfoEXT is not nothrow_move_constructible!" );
|
"DebugMarkerMarkerInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
#if defined( VK_ENABLE_BETA_EXTENSIONS )
|
|
||||||
//=== VK_KHR_video_queue ===
|
//=== VK_KHR_video_queue ===
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoSessionKHR ) == sizeof( VkVideoSessionKHR ), "handle and wrapper have different size!" );
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoSessionKHR ) == sizeof( VkVideoSessionKHR ), "handle and wrapper have different size!" );
|
||||||
@ -2114,9 +2113,7 @@ VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoCodingControlInfoKH
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoCodingControlInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoCodingControlInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoCodingControlInfoKHR>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoCodingControlInfoKHR>::value,
|
||||||
"VideoCodingControlInfoKHR is not nothrow_move_constructible!" );
|
"VideoCodingControlInfoKHR is not nothrow_move_constructible!" );
|
||||||
#endif /*VK_ENABLE_BETA_EXTENSIONS*/
|
|
||||||
|
|
||||||
#if defined( VK_ENABLE_BETA_EXTENSIONS )
|
|
||||||
//=== VK_KHR_video_decode_queue ===
|
//=== VK_KHR_video_decode_queue ===
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeCapabilitiesKHR ) == sizeof( VkVideoDecodeCapabilitiesKHR ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeCapabilitiesKHR ) == sizeof( VkVideoDecodeCapabilitiesKHR ),
|
||||||
@ -2135,7 +2132,6 @@ VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeInfoKHR ) ==
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeInfoKHR>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeInfoKHR>::value,
|
||||||
"VideoDecodeInfoKHR is not nothrow_move_constructible!" );
|
"VideoDecodeInfoKHR is not nothrow_move_constructible!" );
|
||||||
#endif /*VK_ENABLE_BETA_EXTENSIONS*/
|
|
||||||
|
|
||||||
//=== VK_NV_dedicated_allocation ===
|
//=== VK_NV_dedicated_allocation ===
|
||||||
|
|
||||||
@ -2254,21 +2250,6 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEnc
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoEncodeH264VclFrameInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoEncodeH264VclFrameInfoEXT>::value,
|
||||||
"VideoEncodeH264VclFrameInfoEXT is not nothrow_move_constructible!" );
|
"VideoEncodeH264VclFrameInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoEncodeH264ReferenceListsInfoEXT ) == sizeof( VkVideoEncodeH264ReferenceListsInfoEXT ),
|
|
||||||
"struct and wrapper have different size!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEncodeH264ReferenceListsInfoEXT>::value,
|
|
||||||
"struct wrapper is not a standard layout!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoEncodeH264ReferenceListsInfoEXT>::value,
|
|
||||||
"VideoEncodeH264ReferenceListsInfoEXT is not nothrow_move_constructible!" );
|
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoEncodeH264EmitPictureParametersInfoEXT ) ==
|
|
||||||
sizeof( VkVideoEncodeH264EmitPictureParametersInfoEXT ),
|
|
||||||
"struct and wrapper have different size!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEncodeH264EmitPictureParametersInfoEXT>::value,
|
|
||||||
"struct wrapper is not a standard layout!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoEncodeH264EmitPictureParametersInfoEXT>::value,
|
|
||||||
"VideoEncodeH264EmitPictureParametersInfoEXT is not nothrow_move_constructible!" );
|
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoEncodeH264DpbSlotInfoEXT ) == sizeof( VkVideoEncodeH264DpbSlotInfoEXT ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoEncodeH264DpbSlotInfoEXT ) == sizeof( VkVideoEncodeH264DpbSlotInfoEXT ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEncodeH264DpbSlotInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEncodeH264DpbSlotInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
||||||
@ -2342,14 +2323,6 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEnc
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoEncodeH265VclFrameInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoEncodeH265VclFrameInfoEXT>::value,
|
||||||
"VideoEncodeH265VclFrameInfoEXT is not nothrow_move_constructible!" );
|
"VideoEncodeH265VclFrameInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoEncodeH265EmitPictureParametersInfoEXT ) ==
|
|
||||||
sizeof( VkVideoEncodeH265EmitPictureParametersInfoEXT ),
|
|
||||||
"struct and wrapper have different size!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEncodeH265EmitPictureParametersInfoEXT>::value,
|
|
||||||
"struct wrapper is not a standard layout!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoEncodeH265EmitPictureParametersInfoEXT>::value,
|
|
||||||
"VideoEncodeH265EmitPictureParametersInfoEXT is not nothrow_move_constructible!" );
|
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoEncodeH265DpbSlotInfoEXT ) == sizeof( VkVideoEncodeH265DpbSlotInfoEXT ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoEncodeH265DpbSlotInfoEXT ) == sizeof( VkVideoEncodeH265DpbSlotInfoEXT ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEncodeH265DpbSlotInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEncodeH265DpbSlotInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
||||||
@ -2369,13 +2342,6 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEnc
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoEncodeH265ProfileInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoEncodeH265ProfileInfoEXT>::value,
|
||||||
"VideoEncodeH265ProfileInfoEXT is not nothrow_move_constructible!" );
|
"VideoEncodeH265ProfileInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoEncodeH265ReferenceListsInfoEXT ) == sizeof( VkVideoEncodeH265ReferenceListsInfoEXT ),
|
|
||||||
"struct and wrapper have different size!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEncodeH265ReferenceListsInfoEXT>::value,
|
|
||||||
"struct wrapper is not a standard layout!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoEncodeH265ReferenceListsInfoEXT>::value,
|
|
||||||
"VideoEncodeH265ReferenceListsInfoEXT is not nothrow_move_constructible!" );
|
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoEncodeH265RateControlInfoEXT ) == sizeof( VkVideoEncodeH265RateControlInfoEXT ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoEncodeH265RateControlInfoEXT ) == sizeof( VkVideoEncodeH265RateControlInfoEXT ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEncodeH265RateControlInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEncodeH265RateControlInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
||||||
@ -2401,48 +2367,46 @@ VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPAC
|
|||||||
"VideoEncodeH265FrameSizeEXT is not nothrow_move_constructible!" );
|
"VideoEncodeH265FrameSizeEXT is not nothrow_move_constructible!" );
|
||||||
#endif /*VK_ENABLE_BETA_EXTENSIONS*/
|
#endif /*VK_ENABLE_BETA_EXTENSIONS*/
|
||||||
|
|
||||||
#if defined( VK_ENABLE_BETA_EXTENSIONS )
|
//=== VK_KHR_video_decode_h264 ===
|
||||||
//=== VK_EXT_video_decode_h264 ===
|
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH264ProfileInfoEXT ) == sizeof( VkVideoDecodeH264ProfileInfoEXT ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH264ProfileInfoKHR ) == sizeof( VkVideoDecodeH264ProfileInfoKHR ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH264ProfileInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH264ProfileInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH264ProfileInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH264ProfileInfoKHR>::value,
|
||||||
"VideoDecodeH264ProfileInfoEXT is not nothrow_move_constructible!" );
|
"VideoDecodeH264ProfileInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH264CapabilitiesEXT ) == sizeof( VkVideoDecodeH264CapabilitiesEXT ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH264CapabilitiesKHR ) == sizeof( VkVideoDecodeH264CapabilitiesKHR ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH264CapabilitiesEXT>::value, "struct wrapper is not a standard layout!" );
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH264CapabilitiesKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH264CapabilitiesEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH264CapabilitiesKHR>::value,
|
||||||
"VideoDecodeH264CapabilitiesEXT is not nothrow_move_constructible!" );
|
"VideoDecodeH264CapabilitiesKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH264SessionParametersCreateInfoEXT ) ==
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH264SessionParametersCreateInfoKHR ) ==
|
||||||
sizeof( VkVideoDecodeH264SessionParametersCreateInfoEXT ),
|
sizeof( VkVideoDecodeH264SessionParametersCreateInfoKHR ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH264SessionParametersCreateInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH264SessionParametersCreateInfoKHR>::value,
|
||||||
"struct wrapper is not a standard layout!" );
|
"struct wrapper is not a standard layout!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH264SessionParametersCreateInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH264SessionParametersCreateInfoKHR>::value,
|
||||||
"VideoDecodeH264SessionParametersCreateInfoEXT is not nothrow_move_constructible!" );
|
"VideoDecodeH264SessionParametersCreateInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH264SessionParametersAddInfoEXT ) == sizeof( VkVideoDecodeH264SessionParametersAddInfoEXT ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH264SessionParametersAddInfoKHR ) == sizeof( VkVideoDecodeH264SessionParametersAddInfoKHR ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH264SessionParametersAddInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH264SessionParametersAddInfoKHR>::value,
|
||||||
"struct wrapper is not a standard layout!" );
|
"struct wrapper is not a standard layout!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH264SessionParametersAddInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH264SessionParametersAddInfoKHR>::value,
|
||||||
"VideoDecodeH264SessionParametersAddInfoEXT is not nothrow_move_constructible!" );
|
"VideoDecodeH264SessionParametersAddInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH264PictureInfoEXT ) == sizeof( VkVideoDecodeH264PictureInfoEXT ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH264PictureInfoKHR ) == sizeof( VkVideoDecodeH264PictureInfoKHR ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH264PictureInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH264PictureInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH264PictureInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH264PictureInfoKHR>::value,
|
||||||
"VideoDecodeH264PictureInfoEXT is not nothrow_move_constructible!" );
|
"VideoDecodeH264PictureInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH264DpbSlotInfoEXT ) == sizeof( VkVideoDecodeH264DpbSlotInfoEXT ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH264DpbSlotInfoKHR ) == sizeof( VkVideoDecodeH264DpbSlotInfoKHR ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH264DpbSlotInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH264DpbSlotInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH264DpbSlotInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH264DpbSlotInfoKHR>::value,
|
||||||
"VideoDecodeH264DpbSlotInfoEXT is not nothrow_move_constructible!" );
|
"VideoDecodeH264DpbSlotInfoKHR is not nothrow_move_constructible!" );
|
||||||
#endif /*VK_ENABLE_BETA_EXTENSIONS*/
|
|
||||||
|
|
||||||
//=== VK_AMD_texture_gather_bias_lod ===
|
//=== VK_AMD_texture_gather_bias_lod ===
|
||||||
|
|
||||||
@ -3427,6 +3391,64 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::Accelera
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::AccelerationStructureBuildSizesInfoKHR>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::AccelerationStructureBuildSizesInfoKHR>::value,
|
||||||
"AccelerationStructureBuildSizesInfoKHR is not nothrow_move_constructible!" );
|
"AccelerationStructureBuildSizesInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_KHR_ray_tracing_pipeline ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::RayTracingShaderGroupCreateInfoKHR ) == sizeof( VkRayTracingShaderGroupCreateInfoKHR ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::RayTracingShaderGroupCreateInfoKHR>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::RayTracingShaderGroupCreateInfoKHR>::value,
|
||||||
|
"RayTracingShaderGroupCreateInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::RayTracingPipelineCreateInfoKHR ) == sizeof( VkRayTracingPipelineCreateInfoKHR ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::RayTracingPipelineCreateInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::RayTracingPipelineCreateInfoKHR>::value,
|
||||||
|
"RayTracingPipelineCreateInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPipelineFeaturesKHR ) ==
|
||||||
|
sizeof( VkPhysicalDeviceRayTracingPipelineFeaturesKHR ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPipelineFeaturesKHR>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPipelineFeaturesKHR>::value,
|
||||||
|
"PhysicalDeviceRayTracingPipelineFeaturesKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPipelinePropertiesKHR ) ==
|
||||||
|
sizeof( VkPhysicalDeviceRayTracingPipelinePropertiesKHR ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPipelinePropertiesKHR>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPipelinePropertiesKHR>::value,
|
||||||
|
"PhysicalDeviceRayTracingPipelinePropertiesKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::StridedDeviceAddressRegionKHR ) == sizeof( VkStridedDeviceAddressRegionKHR ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::StridedDeviceAddressRegionKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::StridedDeviceAddressRegionKHR>::value,
|
||||||
|
"StridedDeviceAddressRegionKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::TraceRaysIndirectCommandKHR ) == sizeof( VkTraceRaysIndirectCommandKHR ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::TraceRaysIndirectCommandKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::TraceRaysIndirectCommandKHR>::value,
|
||||||
|
"TraceRaysIndirectCommandKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::RayTracingPipelineInterfaceCreateInfoKHR ) == sizeof( VkRayTracingPipelineInterfaceCreateInfoKHR ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::RayTracingPipelineInterfaceCreateInfoKHR>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::RayTracingPipelineInterfaceCreateInfoKHR>::value,
|
||||||
|
"RayTracingPipelineInterfaceCreateInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_KHR_ray_query ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceRayQueryFeaturesKHR ) == sizeof( VkPhysicalDeviceRayQueryFeaturesKHR ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayQueryFeaturesKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayQueryFeaturesKHR>::value,
|
||||||
|
"PhysicalDeviceRayQueryFeaturesKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
//=== VK_NV_framebuffer_mixed_samples ===
|
//=== VK_NV_framebuffer_mixed_samples ===
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PipelineCoverageModulationStateCreateInfoNV ) ==
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PipelineCoverageModulationStateCreateInfoNV ) ==
|
||||||
@ -3769,48 +3791,46 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::Physical
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderCorePropertiesAMD>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderCorePropertiesAMD>::value,
|
||||||
"PhysicalDeviceShaderCorePropertiesAMD is not nothrow_move_constructible!" );
|
"PhysicalDeviceShaderCorePropertiesAMD is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
#if defined( VK_ENABLE_BETA_EXTENSIONS )
|
//=== VK_KHR_video_decode_h265 ===
|
||||||
//=== VK_EXT_video_decode_h265 ===
|
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH265ProfileInfoEXT ) == sizeof( VkVideoDecodeH265ProfileInfoEXT ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH265ProfileInfoKHR ) == sizeof( VkVideoDecodeH265ProfileInfoKHR ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH265ProfileInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH265ProfileInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH265ProfileInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH265ProfileInfoKHR>::value,
|
||||||
"VideoDecodeH265ProfileInfoEXT is not nothrow_move_constructible!" );
|
"VideoDecodeH265ProfileInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH265CapabilitiesEXT ) == sizeof( VkVideoDecodeH265CapabilitiesEXT ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH265CapabilitiesKHR ) == sizeof( VkVideoDecodeH265CapabilitiesKHR ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH265CapabilitiesEXT>::value, "struct wrapper is not a standard layout!" );
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH265CapabilitiesKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH265CapabilitiesEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH265CapabilitiesKHR>::value,
|
||||||
"VideoDecodeH265CapabilitiesEXT is not nothrow_move_constructible!" );
|
"VideoDecodeH265CapabilitiesKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH265SessionParametersCreateInfoEXT ) ==
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH265SessionParametersCreateInfoKHR ) ==
|
||||||
sizeof( VkVideoDecodeH265SessionParametersCreateInfoEXT ),
|
sizeof( VkVideoDecodeH265SessionParametersCreateInfoKHR ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH265SessionParametersCreateInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH265SessionParametersCreateInfoKHR>::value,
|
||||||
"struct wrapper is not a standard layout!" );
|
"struct wrapper is not a standard layout!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH265SessionParametersCreateInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH265SessionParametersCreateInfoKHR>::value,
|
||||||
"VideoDecodeH265SessionParametersCreateInfoEXT is not nothrow_move_constructible!" );
|
"VideoDecodeH265SessionParametersCreateInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH265SessionParametersAddInfoEXT ) == sizeof( VkVideoDecodeH265SessionParametersAddInfoEXT ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH265SessionParametersAddInfoKHR ) == sizeof( VkVideoDecodeH265SessionParametersAddInfoKHR ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH265SessionParametersAddInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH265SessionParametersAddInfoKHR>::value,
|
||||||
"struct wrapper is not a standard layout!" );
|
"struct wrapper is not a standard layout!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH265SessionParametersAddInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH265SessionParametersAddInfoKHR>::value,
|
||||||
"VideoDecodeH265SessionParametersAddInfoEXT is not nothrow_move_constructible!" );
|
"VideoDecodeH265SessionParametersAddInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH265PictureInfoEXT ) == sizeof( VkVideoDecodeH265PictureInfoEXT ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH265PictureInfoKHR ) == sizeof( VkVideoDecodeH265PictureInfoKHR ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH265PictureInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH265PictureInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH265PictureInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH265PictureInfoKHR>::value,
|
||||||
"VideoDecodeH265PictureInfoEXT is not nothrow_move_constructible!" );
|
"VideoDecodeH265PictureInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH265DpbSlotInfoEXT ) == sizeof( VkVideoDecodeH265DpbSlotInfoEXT ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoDecodeH265DpbSlotInfoKHR ) == sizeof( VkVideoDecodeH265DpbSlotInfoKHR ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH265DpbSlotInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoDecodeH265DpbSlotInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH265DpbSlotInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoDecodeH265DpbSlotInfoKHR>::value,
|
||||||
"VideoDecodeH265DpbSlotInfoEXT is not nothrow_move_constructible!" );
|
"VideoDecodeH265DpbSlotInfoKHR is not nothrow_move_constructible!" );
|
||||||
#endif /*VK_ENABLE_BETA_EXTENSIONS*/
|
|
||||||
|
|
||||||
//=== VK_KHR_global_priority ===
|
//=== VK_KHR_global_priority ===
|
||||||
|
|
||||||
@ -4468,6 +4488,18 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::Pipeline
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PipelineExecutableInternalRepresentationKHR>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PipelineExecutableInternalRepresentationKHR>::value,
|
||||||
"PipelineExecutableInternalRepresentationKHR is not nothrow_move_constructible!" );
|
"PipelineExecutableInternalRepresentationKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_KHR_map_memory2 ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::MemoryMapInfoKHR ) == sizeof( VkMemoryMapInfoKHR ), "struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::MemoryMapInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::MemoryMapInfoKHR>::value,
|
||||||
|
"MemoryMapInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::MemoryUnmapInfoKHR ) == sizeof( VkMemoryUnmapInfoKHR ), "struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::MemoryUnmapInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::MemoryUnmapInfoKHR>::value,
|
||||||
|
"MemoryUnmapInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
//=== VK_EXT_shader_atomic_float2 ===
|
//=== VK_EXT_shader_atomic_float2 ===
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderAtomicFloat2FeaturesEXT ) ==
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderAtomicFloat2FeaturesEXT ) ==
|
||||||
@ -4478,6 +4510,70 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::Physical
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderAtomicFloat2FeaturesEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderAtomicFloat2FeaturesEXT>::value,
|
||||||
"PhysicalDeviceShaderAtomicFloat2FeaturesEXT is not nothrow_move_constructible!" );
|
"PhysicalDeviceShaderAtomicFloat2FeaturesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_EXT_surface_maintenance1 ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::SurfacePresentModeEXT ) == sizeof( VkSurfacePresentModeEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::SurfacePresentModeEXT>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::SurfacePresentModeEXT>::value,
|
||||||
|
"SurfacePresentModeEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::SurfacePresentScalingCapabilitiesEXT ) == sizeof( VkSurfacePresentScalingCapabilitiesEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::SurfacePresentScalingCapabilitiesEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::SurfacePresentScalingCapabilitiesEXT>::value,
|
||||||
|
"SurfacePresentScalingCapabilitiesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::SurfacePresentModeCompatibilityEXT ) == sizeof( VkSurfacePresentModeCompatibilityEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::SurfacePresentModeCompatibilityEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::SurfacePresentModeCompatibilityEXT>::value,
|
||||||
|
"SurfacePresentModeCompatibilityEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_EXT_swapchain_maintenance1 ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceSwapchainMaintenance1FeaturesEXT ) ==
|
||||||
|
sizeof( VkPhysicalDeviceSwapchainMaintenance1FeaturesEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceSwapchainMaintenance1FeaturesEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceSwapchainMaintenance1FeaturesEXT>::value,
|
||||||
|
"PhysicalDeviceSwapchainMaintenance1FeaturesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::SwapchainPresentFenceInfoEXT ) == sizeof( VkSwapchainPresentFenceInfoEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::SwapchainPresentFenceInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::SwapchainPresentFenceInfoEXT>::value,
|
||||||
|
"SwapchainPresentFenceInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::SwapchainPresentModesCreateInfoEXT ) == sizeof( VkSwapchainPresentModesCreateInfoEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::SwapchainPresentModesCreateInfoEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::SwapchainPresentModesCreateInfoEXT>::value,
|
||||||
|
"SwapchainPresentModesCreateInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::SwapchainPresentModeInfoEXT ) == sizeof( VkSwapchainPresentModeInfoEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::SwapchainPresentModeInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::SwapchainPresentModeInfoEXT>::value,
|
||||||
|
"SwapchainPresentModeInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::SwapchainPresentScalingCreateInfoEXT ) == sizeof( VkSwapchainPresentScalingCreateInfoEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::SwapchainPresentScalingCreateInfoEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::SwapchainPresentScalingCreateInfoEXT>::value,
|
||||||
|
"SwapchainPresentScalingCreateInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::ReleaseSwapchainImagesInfoEXT ) == sizeof( VkReleaseSwapchainImagesInfoEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::ReleaseSwapchainImagesInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::ReleaseSwapchainImagesInfoEXT>::value,
|
||||||
|
"ReleaseSwapchainImagesInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
//=== VK_NV_device_generated_commands ===
|
//=== VK_NV_device_generated_commands ===
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceDeviceGeneratedCommandsPropertiesNV ) ==
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceDeviceGeneratedCommandsPropertiesNV ) ==
|
||||||
@ -4735,6 +4831,13 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEnc
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoEncodeCapabilitiesKHR>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::VideoEncodeCapabilitiesKHR>::value,
|
||||||
"VideoEncodeCapabilitiesKHR is not nothrow_move_constructible!" );
|
"VideoEncodeCapabilitiesKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::QueryPoolVideoEncodeFeedbackCreateInfoKHR ) == sizeof( VkQueryPoolVideoEncodeFeedbackCreateInfoKHR ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::QueryPoolVideoEncodeFeedbackCreateInfoKHR>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::QueryPoolVideoEncodeFeedbackCreateInfoKHR>::value,
|
||||||
|
"QueryPoolVideoEncodeFeedbackCreateInfoKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoEncodeUsageInfoKHR ) == sizeof( VkVideoEncodeUsageInfoKHR ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::VideoEncodeUsageInfoKHR ) == sizeof( VkVideoEncodeUsageInfoKHR ),
|
||||||
"struct and wrapper have different size!" );
|
"struct and wrapper have different size!" );
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEncodeUsageInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::VideoEncodeUsageInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
||||||
@ -4771,6 +4874,14 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::DeviceDi
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::DeviceDiagnosticsConfigCreateInfoNV>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::DeviceDiagnosticsConfigCreateInfoNV>::value,
|
||||||
"DeviceDiagnosticsConfigCreateInfoNV is not nothrow_move_constructible!" );
|
"DeviceDiagnosticsConfigCreateInfoNV is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_NV_low_latency ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::QueryLowLatencySupportNV ) == sizeof( VkQueryLowLatencySupportNV ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::QueryLowLatencySupportNV>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::QueryLowLatencySupportNV>::value,
|
||||||
|
"QueryLowLatencySupportNV is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
#if defined( VK_USE_PLATFORM_METAL_EXT )
|
#if defined( VK_USE_PLATFORM_METAL_EXT )
|
||||||
//=== VK_EXT_metal_objects ===
|
//=== VK_EXT_metal_objects ===
|
||||||
|
|
||||||
@ -4861,6 +4972,103 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::Checkpoi
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::CheckpointData2NV>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::CheckpointData2NV>::value,
|
||||||
"CheckpointData2NV is not nothrow_move_constructible!" );
|
"CheckpointData2NV is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_EXT_descriptor_buffer ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceDescriptorBufferPropertiesEXT ) ==
|
||||||
|
sizeof( VkPhysicalDeviceDescriptorBufferPropertiesEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceDescriptorBufferPropertiesEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceDescriptorBufferPropertiesEXT>::value,
|
||||||
|
"PhysicalDeviceDescriptorBufferPropertiesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceDescriptorBufferDensityMapPropertiesEXT ) ==
|
||||||
|
sizeof( VkPhysicalDeviceDescriptorBufferDensityMapPropertiesEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceDescriptorBufferDensityMapPropertiesEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceDescriptorBufferDensityMapPropertiesEXT>::value,
|
||||||
|
"PhysicalDeviceDescriptorBufferDensityMapPropertiesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceDescriptorBufferFeaturesEXT ) == sizeof( VkPhysicalDeviceDescriptorBufferFeaturesEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceDescriptorBufferFeaturesEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceDescriptorBufferFeaturesEXT>::value,
|
||||||
|
"PhysicalDeviceDescriptorBufferFeaturesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::DescriptorAddressInfoEXT ) == sizeof( VkDescriptorAddressInfoEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::DescriptorAddressInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::DescriptorAddressInfoEXT>::value,
|
||||||
|
"DescriptorAddressInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::DescriptorBufferBindingInfoEXT ) == sizeof( VkDescriptorBufferBindingInfoEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::DescriptorBufferBindingInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::DescriptorBufferBindingInfoEXT>::value,
|
||||||
|
"DescriptorBufferBindingInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::DescriptorBufferBindingPushDescriptorBufferHandleEXT ) ==
|
||||||
|
sizeof( VkDescriptorBufferBindingPushDescriptorBufferHandleEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::DescriptorBufferBindingPushDescriptorBufferHandleEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::DescriptorBufferBindingPushDescriptorBufferHandleEXT>::value,
|
||||||
|
"DescriptorBufferBindingPushDescriptorBufferHandleEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::DescriptorDataEXT ) == sizeof( VkDescriptorDataEXT ), "struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::DescriptorDataEXT>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::DescriptorDataEXT>::value,
|
||||||
|
"DescriptorDataEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::DescriptorGetInfoEXT ) == sizeof( VkDescriptorGetInfoEXT ), "struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::DescriptorGetInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::DescriptorGetInfoEXT>::value,
|
||||||
|
"DescriptorGetInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::BufferCaptureDescriptorDataInfoEXT ) == sizeof( VkBufferCaptureDescriptorDataInfoEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::BufferCaptureDescriptorDataInfoEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::BufferCaptureDescriptorDataInfoEXT>::value,
|
||||||
|
"BufferCaptureDescriptorDataInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::ImageCaptureDescriptorDataInfoEXT ) == sizeof( VkImageCaptureDescriptorDataInfoEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::ImageCaptureDescriptorDataInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::ImageCaptureDescriptorDataInfoEXT>::value,
|
||||||
|
"ImageCaptureDescriptorDataInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::ImageViewCaptureDescriptorDataInfoEXT ) == sizeof( VkImageViewCaptureDescriptorDataInfoEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::ImageViewCaptureDescriptorDataInfoEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::ImageViewCaptureDescriptorDataInfoEXT>::value,
|
||||||
|
"ImageViewCaptureDescriptorDataInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::SamplerCaptureDescriptorDataInfoEXT ) == sizeof( VkSamplerCaptureDescriptorDataInfoEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::SamplerCaptureDescriptorDataInfoEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::SamplerCaptureDescriptorDataInfoEXT>::value,
|
||||||
|
"SamplerCaptureDescriptorDataInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::OpaqueCaptureDescriptorDataCreateInfoEXT ) == sizeof( VkOpaqueCaptureDescriptorDataCreateInfoEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::OpaqueCaptureDescriptorDataCreateInfoEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::OpaqueCaptureDescriptorDataCreateInfoEXT>::value,
|
||||||
|
"OpaqueCaptureDescriptorDataCreateInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::AccelerationStructureCaptureDescriptorDataInfoEXT ) ==
|
||||||
|
sizeof( VkAccelerationStructureCaptureDescriptorDataInfoEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::AccelerationStructureCaptureDescriptorDataInfoEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::AccelerationStructureCaptureDescriptorDataInfoEXT>::value,
|
||||||
|
"AccelerationStructureCaptureDescriptorDataInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
//=== VK_EXT_graphics_pipeline_library ===
|
//=== VK_EXT_graphics_pipeline_library ===
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceGraphicsPipelineLibraryFeaturesEXT ) ==
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceGraphicsPipelineLibraryFeaturesEXT ) ==
|
||||||
@ -5183,64 +5391,6 @@ VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPAC
|
|||||||
"DirectFBSurfaceCreateInfoEXT is not nothrow_move_constructible!" );
|
"DirectFBSurfaceCreateInfoEXT is not nothrow_move_constructible!" );
|
||||||
#endif /*VK_USE_PLATFORM_DIRECTFB_EXT*/
|
#endif /*VK_USE_PLATFORM_DIRECTFB_EXT*/
|
||||||
|
|
||||||
//=== VK_KHR_ray_tracing_pipeline ===
|
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::RayTracingShaderGroupCreateInfoKHR ) == sizeof( VkRayTracingShaderGroupCreateInfoKHR ),
|
|
||||||
"struct and wrapper have different size!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::RayTracingShaderGroupCreateInfoKHR>::value,
|
|
||||||
"struct wrapper is not a standard layout!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::RayTracingShaderGroupCreateInfoKHR>::value,
|
|
||||||
"RayTracingShaderGroupCreateInfoKHR is not nothrow_move_constructible!" );
|
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::RayTracingPipelineCreateInfoKHR ) == sizeof( VkRayTracingPipelineCreateInfoKHR ),
|
|
||||||
"struct and wrapper have different size!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::RayTracingPipelineCreateInfoKHR>::value, "struct wrapper is not a standard layout!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::RayTracingPipelineCreateInfoKHR>::value,
|
|
||||||
"RayTracingPipelineCreateInfoKHR is not nothrow_move_constructible!" );
|
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPipelineFeaturesKHR ) ==
|
|
||||||
sizeof( VkPhysicalDeviceRayTracingPipelineFeaturesKHR ),
|
|
||||||
"struct and wrapper have different size!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPipelineFeaturesKHR>::value,
|
|
||||||
"struct wrapper is not a standard layout!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPipelineFeaturesKHR>::value,
|
|
||||||
"PhysicalDeviceRayTracingPipelineFeaturesKHR is not nothrow_move_constructible!" );
|
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPipelinePropertiesKHR ) ==
|
|
||||||
sizeof( VkPhysicalDeviceRayTracingPipelinePropertiesKHR ),
|
|
||||||
"struct and wrapper have different size!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPipelinePropertiesKHR>::value,
|
|
||||||
"struct wrapper is not a standard layout!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPipelinePropertiesKHR>::value,
|
|
||||||
"PhysicalDeviceRayTracingPipelinePropertiesKHR is not nothrow_move_constructible!" );
|
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::StridedDeviceAddressRegionKHR ) == sizeof( VkStridedDeviceAddressRegionKHR ),
|
|
||||||
"struct and wrapper have different size!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::StridedDeviceAddressRegionKHR>::value, "struct wrapper is not a standard layout!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::StridedDeviceAddressRegionKHR>::value,
|
|
||||||
"StridedDeviceAddressRegionKHR is not nothrow_move_constructible!" );
|
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::TraceRaysIndirectCommandKHR ) == sizeof( VkTraceRaysIndirectCommandKHR ),
|
|
||||||
"struct and wrapper have different size!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::TraceRaysIndirectCommandKHR>::value, "struct wrapper is not a standard layout!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::TraceRaysIndirectCommandKHR>::value,
|
|
||||||
"TraceRaysIndirectCommandKHR is not nothrow_move_constructible!" );
|
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::RayTracingPipelineInterfaceCreateInfoKHR ) == sizeof( VkRayTracingPipelineInterfaceCreateInfoKHR ),
|
|
||||||
"struct and wrapper have different size!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::RayTracingPipelineInterfaceCreateInfoKHR>::value,
|
|
||||||
"struct wrapper is not a standard layout!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::RayTracingPipelineInterfaceCreateInfoKHR>::value,
|
|
||||||
"RayTracingPipelineInterfaceCreateInfoKHR is not nothrow_move_constructible!" );
|
|
||||||
|
|
||||||
//=== VK_KHR_ray_query ===
|
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceRayQueryFeaturesKHR ) == sizeof( VkPhysicalDeviceRayQueryFeaturesKHR ),
|
|
||||||
"struct and wrapper have different size!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayQueryFeaturesKHR>::value, "struct wrapper is not a standard layout!" );
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayQueryFeaturesKHR>::value,
|
|
||||||
"PhysicalDeviceRayQueryFeaturesKHR is not nothrow_move_constructible!" );
|
|
||||||
|
|
||||||
//=== VK_EXT_vertex_input_dynamic_state ===
|
//=== VK_EXT_vertex_input_dynamic_state ===
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceVertexInputDynamicStateFeaturesEXT ) ==
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceVertexInputDynamicStateFeaturesEXT ) ==
|
||||||
@ -5630,6 +5780,22 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::Physical
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceImage2DViewOf3DFeaturesEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceImage2DViewOf3DFeaturesEXT>::value,
|
||||||
"PhysicalDeviceImage2DViewOf3DFeaturesEXT is not nothrow_move_constructible!" );
|
"PhysicalDeviceImage2DViewOf3DFeaturesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_EXT_shader_tile_image ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderTileImageFeaturesEXT ) == sizeof( VkPhysicalDeviceShaderTileImageFeaturesEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderTileImageFeaturesEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderTileImageFeaturesEXT>::value,
|
||||||
|
"PhysicalDeviceShaderTileImageFeaturesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderTileImagePropertiesEXT ) == sizeof( VkPhysicalDeviceShaderTileImagePropertiesEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderTileImagePropertiesEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderTileImagePropertiesEXT>::value,
|
||||||
|
"PhysicalDeviceShaderTileImagePropertiesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
//=== VK_EXT_opacity_micromap ===
|
//=== VK_EXT_opacity_micromap ===
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::MicromapBuildInfoEXT ) == sizeof( VkMicromapBuildInfoEXT ), "struct and wrapper have different size!" );
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::MicromapBuildInfoEXT ) == sizeof( VkMicromapBuildInfoEXT ), "struct and wrapper have different size!" );
|
||||||
@ -5707,6 +5873,52 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::Micromap
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::MicromapTriangleEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::MicromapTriangleEXT>::value,
|
||||||
"MicromapTriangleEXT is not nothrow_move_constructible!" );
|
"MicromapTriangleEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
#if defined( VK_ENABLE_BETA_EXTENSIONS )
|
||||||
|
//=== VK_NV_displacement_micromap ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceDisplacementMicromapFeaturesNV ) ==
|
||||||
|
sizeof( VkPhysicalDeviceDisplacementMicromapFeaturesNV ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceDisplacementMicromapFeaturesNV>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceDisplacementMicromapFeaturesNV>::value,
|
||||||
|
"PhysicalDeviceDisplacementMicromapFeaturesNV is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceDisplacementMicromapPropertiesNV ) ==
|
||||||
|
sizeof( VkPhysicalDeviceDisplacementMicromapPropertiesNV ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceDisplacementMicromapPropertiesNV>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceDisplacementMicromapPropertiesNV>::value,
|
||||||
|
"PhysicalDeviceDisplacementMicromapPropertiesNV is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::AccelerationStructureTrianglesDisplacementMicromapNV ) ==
|
||||||
|
sizeof( VkAccelerationStructureTrianglesDisplacementMicromapNV ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::AccelerationStructureTrianglesDisplacementMicromapNV>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::AccelerationStructureTrianglesDisplacementMicromapNV>::value,
|
||||||
|
"AccelerationStructureTrianglesDisplacementMicromapNV is not nothrow_move_constructible!" );
|
||||||
|
#endif /*VK_ENABLE_BETA_EXTENSIONS*/
|
||||||
|
|
||||||
|
//=== VK_HUAWEI_cluster_culling_shader ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceClusterCullingShaderFeaturesHUAWEI ) ==
|
||||||
|
sizeof( VkPhysicalDeviceClusterCullingShaderFeaturesHUAWEI ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceClusterCullingShaderFeaturesHUAWEI>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceClusterCullingShaderFeaturesHUAWEI>::value,
|
||||||
|
"PhysicalDeviceClusterCullingShaderFeaturesHUAWEI is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceClusterCullingShaderPropertiesHUAWEI ) ==
|
||||||
|
sizeof( VkPhysicalDeviceClusterCullingShaderPropertiesHUAWEI ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceClusterCullingShaderPropertiesHUAWEI>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceClusterCullingShaderPropertiesHUAWEI>::value,
|
||||||
|
"PhysicalDeviceClusterCullingShaderPropertiesHUAWEI is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
//=== VK_EXT_border_color_swizzle ===
|
//=== VK_EXT_border_color_swizzle ===
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceBorderColorSwizzleFeaturesEXT ) ==
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceBorderColorSwizzleFeaturesEXT ) ==
|
||||||
@ -5735,6 +5947,31 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::Physical
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDevicePageableDeviceLocalMemoryFeaturesEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDevicePageableDeviceLocalMemoryFeaturesEXT>::value,
|
||||||
"PhysicalDevicePageableDeviceLocalMemoryFeaturesEXT is not nothrow_move_constructible!" );
|
"PhysicalDevicePageableDeviceLocalMemoryFeaturesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_ARM_shader_core_properties ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderCorePropertiesARM ) == sizeof( VkPhysicalDeviceShaderCorePropertiesARM ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderCorePropertiesARM>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderCorePropertiesARM>::value,
|
||||||
|
"PhysicalDeviceShaderCorePropertiesARM is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_EXT_image_sliced_view_of_3d ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceImageSlicedViewOf3DFeaturesEXT ) ==
|
||||||
|
sizeof( VkPhysicalDeviceImageSlicedViewOf3DFeaturesEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceImageSlicedViewOf3DFeaturesEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceImageSlicedViewOf3DFeaturesEXT>::value,
|
||||||
|
"PhysicalDeviceImageSlicedViewOf3DFeaturesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::ImageViewSlicedCreateInfoEXT ) == sizeof( VkImageViewSlicedCreateInfoEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::ImageViewSlicedCreateInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::ImageViewSlicedCreateInfoEXT>::value,
|
||||||
|
"ImageViewSlicedCreateInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
//=== VK_VALVE_descriptor_set_host_mapping ===
|
//=== VK_VALVE_descriptor_set_host_mapping ===
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceDescriptorSetHostMappingFeaturesVALVE ) ==
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceDescriptorSetHostMappingFeaturesVALVE ) ==
|
||||||
@ -5803,6 +6040,60 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::SubpassF
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::SubpassFragmentDensityMapOffsetEndInfoQCOM>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::SubpassFragmentDensityMapOffsetEndInfoQCOM>::value,
|
||||||
"SubpassFragmentDensityMapOffsetEndInfoQCOM is not nothrow_move_constructible!" );
|
"SubpassFragmentDensityMapOffsetEndInfoQCOM is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_NV_copy_memory_indirect ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::CopyMemoryIndirectCommandNV ) == sizeof( VkCopyMemoryIndirectCommandNV ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::CopyMemoryIndirectCommandNV>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::CopyMemoryIndirectCommandNV>::value,
|
||||||
|
"CopyMemoryIndirectCommandNV is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::CopyMemoryToImageIndirectCommandNV ) == sizeof( VkCopyMemoryToImageIndirectCommandNV ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::CopyMemoryToImageIndirectCommandNV>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::CopyMemoryToImageIndirectCommandNV>::value,
|
||||||
|
"CopyMemoryToImageIndirectCommandNV is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceCopyMemoryIndirectFeaturesNV ) == sizeof( VkPhysicalDeviceCopyMemoryIndirectFeaturesNV ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceCopyMemoryIndirectFeaturesNV>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceCopyMemoryIndirectFeaturesNV>::value,
|
||||||
|
"PhysicalDeviceCopyMemoryIndirectFeaturesNV is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceCopyMemoryIndirectPropertiesNV ) ==
|
||||||
|
sizeof( VkPhysicalDeviceCopyMemoryIndirectPropertiesNV ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceCopyMemoryIndirectPropertiesNV>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceCopyMemoryIndirectPropertiesNV>::value,
|
||||||
|
"PhysicalDeviceCopyMemoryIndirectPropertiesNV is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_NV_memory_decompression ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::DecompressMemoryRegionNV ) == sizeof( VkDecompressMemoryRegionNV ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::DecompressMemoryRegionNV>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::DecompressMemoryRegionNV>::value,
|
||||||
|
"DecompressMemoryRegionNV is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceMemoryDecompressionFeaturesNV ) ==
|
||||||
|
sizeof( VkPhysicalDeviceMemoryDecompressionFeaturesNV ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceMemoryDecompressionFeaturesNV>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceMemoryDecompressionFeaturesNV>::value,
|
||||||
|
"PhysicalDeviceMemoryDecompressionFeaturesNV is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceMemoryDecompressionPropertiesNV ) ==
|
||||||
|
sizeof( VkPhysicalDeviceMemoryDecompressionPropertiesNV ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceMemoryDecompressionPropertiesNV>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceMemoryDecompressionPropertiesNV>::value,
|
||||||
|
"PhysicalDeviceMemoryDecompressionPropertiesNV is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
//=== VK_NV_linear_color_attachment ===
|
//=== VK_NV_linear_color_attachment ===
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceLinearColorAttachmentFeaturesNV ) ==
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceLinearColorAttachmentFeaturesNV ) ==
|
||||||
@ -5919,6 +6210,20 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::RenderPa
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::RenderPassSubpassFeedbackCreateInfoEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::RenderPassSubpassFeedbackCreateInfoEXT>::value,
|
||||||
"RenderPassSubpassFeedbackCreateInfoEXT is not nothrow_move_constructible!" );
|
"RenderPassSubpassFeedbackCreateInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_LUNARG_direct_driver_loading ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::DirectDriverLoadingInfoLUNARG ) == sizeof( VkDirectDriverLoadingInfoLUNARG ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::DirectDriverLoadingInfoLUNARG>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::DirectDriverLoadingInfoLUNARG>::value,
|
||||||
|
"DirectDriverLoadingInfoLUNARG is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::DirectDriverLoadingListLUNARG ) == sizeof( VkDirectDriverLoadingListLUNARG ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::DirectDriverLoadingListLUNARG>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::DirectDriverLoadingListLUNARG>::value,
|
||||||
|
"DirectDriverLoadingListLUNARG is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
//=== VK_EXT_shader_module_identifier ===
|
//=== VK_EXT_shader_module_identifier ===
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderModuleIdentifierFeaturesEXT ) ==
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderModuleIdentifierFeaturesEXT ) ==
|
||||||
@ -6032,6 +6337,40 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::Physical
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDevicePipelineProtectedAccessFeaturesEXT>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDevicePipelineProtectedAccessFeaturesEXT>::value,
|
||||||
"PhysicalDevicePipelineProtectedAccessFeaturesEXT is not nothrow_move_constructible!" );
|
"PhysicalDevicePipelineProtectedAccessFeaturesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_KHR_ray_tracing_position_fetch ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPositionFetchFeaturesKHR ) ==
|
||||||
|
sizeof( VkPhysicalDeviceRayTracingPositionFetchFeaturesKHR ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPositionFetchFeaturesKHR>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingPositionFetchFeaturesKHR>::value,
|
||||||
|
"PhysicalDeviceRayTracingPositionFetchFeaturesKHR is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_EXT_shader_object ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::ShaderEXT ) == sizeof( VkShaderEXT ), "handle and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::ShaderEXT>::value, "ShaderEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderObjectFeaturesEXT ) == sizeof( VkPhysicalDeviceShaderObjectFeaturesEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderObjectFeaturesEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderObjectFeaturesEXT>::value,
|
||||||
|
"PhysicalDeviceShaderObjectFeaturesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderObjectPropertiesEXT ) == sizeof( VkPhysicalDeviceShaderObjectPropertiesEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderObjectPropertiesEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderObjectPropertiesEXT>::value,
|
||||||
|
"PhysicalDeviceShaderObjectPropertiesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::ShaderCreateInfoEXT ) == sizeof( VkShaderCreateInfoEXT ), "struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::ShaderCreateInfoEXT>::value, "struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::ShaderCreateInfoEXT>::value,
|
||||||
|
"ShaderCreateInfoEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
//=== VK_QCOM_tile_properties ===
|
//=== VK_QCOM_tile_properties ===
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceTilePropertiesFeaturesQCOM ) == sizeof( VkPhysicalDeviceTilePropertiesFeaturesQCOM ),
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceTilePropertiesFeaturesQCOM ) == sizeof( VkPhysicalDeviceTilePropertiesFeaturesQCOM ),
|
||||||
@ -6061,6 +6400,34 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::AmigoPro
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::AmigoProfilingSubmitInfoSEC>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::AmigoProfilingSubmitInfoSEC>::value,
|
||||||
"AmigoProfilingSubmitInfoSEC is not nothrow_move_constructible!" );
|
"AmigoProfilingSubmitInfoSEC is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_QCOM_multiview_per_view_viewports ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceMultiviewPerViewViewportsFeaturesQCOM ) ==
|
||||||
|
sizeof( VkPhysicalDeviceMultiviewPerViewViewportsFeaturesQCOM ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceMultiviewPerViewViewportsFeaturesQCOM>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceMultiviewPerViewViewportsFeaturesQCOM>::value,
|
||||||
|
"PhysicalDeviceMultiviewPerViewViewportsFeaturesQCOM is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_NV_ray_tracing_invocation_reorder ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingInvocationReorderPropertiesNV ) ==
|
||||||
|
sizeof( VkPhysicalDeviceRayTracingInvocationReorderPropertiesNV ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingInvocationReorderPropertiesNV>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingInvocationReorderPropertiesNV>::value,
|
||||||
|
"PhysicalDeviceRayTracingInvocationReorderPropertiesNV is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingInvocationReorderFeaturesNV ) ==
|
||||||
|
sizeof( VkPhysicalDeviceRayTracingInvocationReorderFeaturesNV ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingInvocationReorderFeaturesNV>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceRayTracingInvocationReorderFeaturesNV>::value,
|
||||||
|
"PhysicalDeviceRayTracingInvocationReorderFeaturesNV is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
//=== VK_EXT_mutable_descriptor_type ===
|
//=== VK_EXT_mutable_descriptor_type ===
|
||||||
|
|
||||||
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceMutableDescriptorTypeFeaturesEXT ) ==
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceMutableDescriptorTypeFeaturesEXT ) ==
|
||||||
@ -6102,4 +6469,42 @@ VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::Physical
|
|||||||
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderCoreBuiltinsPropertiesARM>::value,
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceShaderCoreBuiltinsPropertiesARM>::value,
|
||||||
"PhysicalDeviceShaderCoreBuiltinsPropertiesARM is not nothrow_move_constructible!" );
|
"PhysicalDeviceShaderCoreBuiltinsPropertiesARM is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_EXT_pipeline_library_group_handles ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDevicePipelineLibraryGroupHandlesFeaturesEXT ) ==
|
||||||
|
sizeof( VkPhysicalDevicePipelineLibraryGroupHandlesFeaturesEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDevicePipelineLibraryGroupHandlesFeaturesEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDevicePipelineLibraryGroupHandlesFeaturesEXT>::value,
|
||||||
|
"PhysicalDevicePipelineLibraryGroupHandlesFeaturesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_QCOM_multiview_per_view_render_areas ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceMultiviewPerViewRenderAreasFeaturesQCOM ) ==
|
||||||
|
sizeof( VkPhysicalDeviceMultiviewPerViewRenderAreasFeaturesQCOM ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceMultiviewPerViewRenderAreasFeaturesQCOM>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceMultiviewPerViewRenderAreasFeaturesQCOM>::value,
|
||||||
|
"PhysicalDeviceMultiviewPerViewRenderAreasFeaturesQCOM is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::MultiviewPerViewRenderAreasRenderPassBeginInfoQCOM ) ==
|
||||||
|
sizeof( VkMultiviewPerViewRenderAreasRenderPassBeginInfoQCOM ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::MultiviewPerViewRenderAreasRenderPassBeginInfoQCOM>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::MultiviewPerViewRenderAreasRenderPassBeginInfoQCOM>::value,
|
||||||
|
"MultiviewPerViewRenderAreasRenderPassBeginInfoQCOM is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
|
//=== VK_EXT_attachment_feedback_loop_dynamic_state ===
|
||||||
|
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( sizeof( VULKAN_HPP_NAMESPACE::PhysicalDeviceAttachmentFeedbackLoopDynamicStateFeaturesEXT ) ==
|
||||||
|
sizeof( VkPhysicalDeviceAttachmentFeedbackLoopDynamicStateFeaturesEXT ),
|
||||||
|
"struct and wrapper have different size!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_standard_layout<VULKAN_HPP_NAMESPACE::PhysicalDeviceAttachmentFeedbackLoopDynamicStateFeaturesEXT>::value,
|
||||||
|
"struct wrapper is not a standard layout!" );
|
||||||
|
VULKAN_HPP_STATIC_ASSERT( std::is_nothrow_move_constructible<VULKAN_HPP_NAMESPACE::PhysicalDeviceAttachmentFeedbackLoopDynamicStateFeaturesEXT>::value,
|
||||||
|
"PhysicalDeviceAttachmentFeedbackLoopDynamicStateFeaturesEXT is not nothrow_move_constructible!" );
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_VI_H_ 1
|
#define VULKAN_VI_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_WAYLAND_H_ 1
|
#define VULKAN_WAYLAND_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_WIN32_H_ 1
|
#define VULKAN_WIN32_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
@ -308,6 +308,24 @@ VKAPI_ATTR VkResult VKAPI_CALL vkGetDeviceGroupSurfacePresentModes2EXT(
|
|||||||
VkDeviceGroupPresentModeFlagsKHR* pModes);
|
VkDeviceGroupPresentModeFlagsKHR* pModes);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#define VK_NV_acquire_winrt_display 1
|
||||||
|
#define VK_NV_ACQUIRE_WINRT_DISPLAY_SPEC_VERSION 1
|
||||||
|
#define VK_NV_ACQUIRE_WINRT_DISPLAY_EXTENSION_NAME "VK_NV_acquire_winrt_display"
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkAcquireWinrtDisplayNV)(VkPhysicalDevice physicalDevice, VkDisplayKHR display);
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkGetWinrtDisplayNV)(VkPhysicalDevice physicalDevice, uint32_t deviceRelativeId, VkDisplayKHR* pDisplay);
|
||||||
|
|
||||||
|
#ifndef VK_NO_PROTOTYPES
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkAcquireWinrtDisplayNV(
|
||||||
|
VkPhysicalDevice physicalDevice,
|
||||||
|
VkDisplayKHR display);
|
||||||
|
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkGetWinrtDisplayNV(
|
||||||
|
VkPhysicalDevice physicalDevice,
|
||||||
|
uint32_t deviceRelativeId,
|
||||||
|
VkDisplayKHR* pDisplay);
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_XCB_H_ 1
|
#define VULKAN_XCB_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_XLIB_H_ 1
|
#define VULKAN_XLIB_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#define VULKAN_XLIB_XRANDR_H_ 1
|
#define VULKAN_XLIB_XRANDR_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright 2015-2022 The Khronos Group Inc.
|
** Copyright 2015-2023 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** SPDX-License-Identifier: Apache-2.0
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#!/usr/bin/python3 -i
|
#!/usr/bin/python3 -i
|
||||||
#
|
#
|
||||||
# Copyright 2021-2022 The Khronos Group Inc.
|
# Copyright 2021-2023 The Khronos Group Inc.
|
||||||
# SPDX-License-Identifier: Apache-2.0
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
# Generic alias for working group-specific API conventions interface.
|
# Generic alias for working group-specific API conventions interface.
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#!/usr/bin/python3 -i
|
#!/usr/bin/python3 -i
|
||||||
#
|
#
|
||||||
# Copyright 2013-2022 The Khronos Group Inc.
|
# Copyright 2013-2023 The Khronos Group Inc.
|
||||||
#
|
#
|
||||||
# SPDX-License-Identifier: Apache-2.0
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
@ -346,6 +346,8 @@ class COutputGenerator(OutputGenerator):
|
|||||||
body += self.genOpts.apientry + noneStr(elem.tail)
|
body += self.genOpts.apientry + noneStr(elem.tail)
|
||||||
else:
|
else:
|
||||||
body += noneStr(elem.text) + noneStr(elem.tail)
|
body += noneStr(elem.text) + noneStr(elem.tail)
|
||||||
|
if category == 'define' and self.misracppstyle():
|
||||||
|
body = body.replace("(uint32_t)", "static_cast<uint32_t>")
|
||||||
if body:
|
if body:
|
||||||
# Add extra newline after multi-line entries.
|
# Add extra newline after multi-line entries.
|
||||||
if '\n' in body[0:-1]:
|
if '\n' in body[0:-1]:
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#!/usr/bin/python3 -i
|
#!/usr/bin/python3 -i
|
||||||
#
|
#
|
||||||
# Copyright 2013-2022 The Khronos Group Inc.
|
# Copyright 2013-2023 The Khronos Group Inc.
|
||||||
#
|
#
|
||||||
# SPDX-License-Identifier: Apache-2.0
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
"""Base class for source/header/doc generators, as well as some utility functions."""
|
"""Base class for source/header/doc generators, as well as some utility functions."""
|
||||||
@ -153,6 +153,7 @@ class GeneratorOptions:
|
|||||||
directory='.',
|
directory='.',
|
||||||
genpath=None,
|
genpath=None,
|
||||||
apiname=None,
|
apiname=None,
|
||||||
|
mergeApiNames=None,
|
||||||
profile=None,
|
profile=None,
|
||||||
versions='.*',
|
versions='.*',
|
||||||
emitversions='.*',
|
emitversions='.*',
|
||||||
@ -176,6 +177,8 @@ class GeneratorOptions:
|
|||||||
- directory - directory in which to generate filename
|
- directory - directory in which to generate filename
|
||||||
- genpath - path to previously generated files, such as apimap.py
|
- genpath - path to previously generated files, such as apimap.py
|
||||||
- apiname - string matching `<api>` 'apiname' attribute, e.g. 'gl'.
|
- apiname - string matching `<api>` 'apiname' attribute, e.g. 'gl'.
|
||||||
|
- mergeApiNames - If not None, a comma separated list of API names
|
||||||
|
to merge into the API specified by 'apiname'
|
||||||
- profile - string specifying API profile , e.g. 'core', or None.
|
- profile - string specifying API profile , e.g. 'core', or None.
|
||||||
- versions - regex matching API versions to process interfaces for.
|
- versions - regex matching API versions to process interfaces for.
|
||||||
Normally `'.*'` or `'[0-9][.][0-9]'` to match all defined versions.
|
Normally `'.*'` or `'[0-9][.][0-9]'` to match all defined versions.
|
||||||
@ -229,6 +232,9 @@ class GeneratorOptions:
|
|||||||
self.apiname = apiname
|
self.apiname = apiname
|
||||||
"string matching `<api>` 'apiname' attribute, e.g. 'gl'."
|
"string matching `<api>` 'apiname' attribute, e.g. 'gl'."
|
||||||
|
|
||||||
|
self.mergeApiNames = mergeApiNames
|
||||||
|
"comma separated list of API names to merge into the API specified by 'apiname'"
|
||||||
|
|
||||||
self.profile = profile
|
self.profile = profile
|
||||||
"string specifying API profile , e.g. 'core', or None."
|
"string specifying API profile , e.g. 'core', or None."
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#!/usr/bin/python3
|
#!/usr/bin/python3
|
||||||
#
|
#
|
||||||
# Copyright 2013-2022 The Khronos Group Inc.
|
# Copyright 2013-2023 The Khronos Group Inc.
|
||||||
#
|
#
|
||||||
# SPDX-License-Identifier: Apache-2.0
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
@ -9,6 +9,7 @@ import os
|
|||||||
import pdb
|
import pdb
|
||||||
import re
|
import re
|
||||||
import sys
|
import sys
|
||||||
|
import copy
|
||||||
import time
|
import time
|
||||||
import xml.etree.ElementTree as etree
|
import xml.etree.ElementTree as etree
|
||||||
|
|
||||||
@ -24,6 +25,7 @@ from generator import write
|
|||||||
from spirvcapgenerator import SpirvCapabilityOutputGenerator
|
from spirvcapgenerator import SpirvCapabilityOutputGenerator
|
||||||
from hostsyncgenerator import HostSynchronizationOutputGenerator
|
from hostsyncgenerator import HostSynchronizationOutputGenerator
|
||||||
from formatsgenerator import FormatsOutputGenerator
|
from formatsgenerator import FormatsOutputGenerator
|
||||||
|
from jsgenerator import JSOutputGenerator
|
||||||
from pygenerator import PyOutputGenerator
|
from pygenerator import PyOutputGenerator
|
||||||
from rubygenerator import RubyOutputGenerator
|
from rubygenerator import RubyOutputGenerator
|
||||||
from reflib import logDiag, logWarn, logErr, setLogFile
|
from reflib import logDiag, logWarn, logErr, setLogFile
|
||||||
@ -119,7 +121,7 @@ def makeGenOpts(args):
|
|||||||
# The SPDX formatting below works around constraints of the 'reuse' tool
|
# The SPDX formatting below works around constraints of the 'reuse' tool
|
||||||
prefixStrings = [
|
prefixStrings = [
|
||||||
'/*',
|
'/*',
|
||||||
'** Copyright 2015-2022 The Khronos Group Inc.',
|
'** Copyright 2015-2023 The Khronos Group Inc.',
|
||||||
'**',
|
'**',
|
||||||
'** SPDX-License-Identifier' + ': Apache-2.0',
|
'** SPDX-License-Identifier' + ': Apache-2.0',
|
||||||
'*/',
|
'*/',
|
||||||
@ -141,7 +143,13 @@ def makeGenOpts(args):
|
|||||||
# An API style conventions object
|
# An API style conventions object
|
||||||
conventions = APIConventions()
|
conventions = APIConventions()
|
||||||
|
|
||||||
defaultAPIName = conventions.xml_api_name
|
if args.apiname is not None:
|
||||||
|
defaultAPIName = args.apiname
|
||||||
|
else:
|
||||||
|
defaultAPIName = conventions.xml_api_name
|
||||||
|
|
||||||
|
# APIs to merge
|
||||||
|
mergeApiNames = args.mergeApiNames
|
||||||
|
|
||||||
# API include files for spec and ref pages
|
# API include files for spec and ref pages
|
||||||
# Overwrites include subdirectories in spec source tree
|
# Overwrites include subdirectories in spec source tree
|
||||||
@ -173,8 +181,26 @@ def makeGenOpts(args):
|
|||||||
expandEnumerants = False)
|
expandEnumerants = False)
|
||||||
]
|
]
|
||||||
|
|
||||||
# Python and Ruby representations of API information, used by scripts
|
# JavaScript, Python, and Ruby representations of API information, used
|
||||||
# that do not need to load the full XML.
|
# by scripts that do not need to load the full XML.
|
||||||
|
genOpts['apimap.cjs'] = [
|
||||||
|
JSOutputGenerator,
|
||||||
|
DocGeneratorOptions(
|
||||||
|
conventions = conventions,
|
||||||
|
filename = 'apimap.cjs',
|
||||||
|
directory = directory,
|
||||||
|
genpath = None,
|
||||||
|
apiname = defaultAPIName,
|
||||||
|
profile = None,
|
||||||
|
versions = featuresPat,
|
||||||
|
emitversions = featuresPat,
|
||||||
|
defaultExtensions = None,
|
||||||
|
addExtensions = addExtensionsPat,
|
||||||
|
removeExtensions = removeExtensionsPat,
|
||||||
|
emitExtensions = emitExtensionsPat,
|
||||||
|
reparentEnums = False)
|
||||||
|
]
|
||||||
|
|
||||||
genOpts['apimap.py'] = [
|
genOpts['apimap.py'] = [
|
||||||
PyOutputGenerator,
|
PyOutputGenerator,
|
||||||
DocGeneratorOptions(
|
DocGeneratorOptions(
|
||||||
@ -357,16 +383,16 @@ def makeGenOpts(args):
|
|||||||
# the extension blocks.
|
# the extension blocks.
|
||||||
betaRequireExtensions = [
|
betaRequireExtensions = [
|
||||||
'VK_KHR_portability_subset',
|
'VK_KHR_portability_subset',
|
||||||
'VK_KHR_video_queue',
|
|
||||||
'VK_KHR_video_decode_queue',
|
|
||||||
'VK_KHR_video_encode_queue',
|
'VK_KHR_video_encode_queue',
|
||||||
'VK_EXT_video_decode_h264',
|
|
||||||
'VK_EXT_video_decode_h265',
|
|
||||||
'VK_EXT_video_encode_h264',
|
'VK_EXT_video_encode_h264',
|
||||||
'VK_EXT_video_encode_h265',
|
'VK_EXT_video_encode_h265',
|
||||||
|
'VK_NV_displacement_micromap',
|
||||||
]
|
]
|
||||||
|
|
||||||
betaSuppressExtensions = []
|
betaSuppressExtensions = [
|
||||||
|
'VK_KHR_video_queue',
|
||||||
|
'VK_EXT_opacity_micromap',
|
||||||
|
]
|
||||||
|
|
||||||
platforms = [
|
platforms = [
|
||||||
[ 'vulkan_android.h', [ 'VK_KHR_android_surface',
|
[ 'vulkan_android.h', [ 'VK_KHR_android_surface',
|
||||||
@ -384,7 +410,7 @@ def makeGenOpts(args):
|
|||||||
[ 'vulkan_macos.h', [ 'VK_MVK_macos_surface' ], commonSuppressExtensions ],
|
[ 'vulkan_macos.h', [ 'VK_MVK_macos_surface' ], commonSuppressExtensions ],
|
||||||
[ 'vulkan_vi.h', [ 'VK_NN_vi_surface' ], commonSuppressExtensions ],
|
[ 'vulkan_vi.h', [ 'VK_NN_vi_surface' ], commonSuppressExtensions ],
|
||||||
[ 'vulkan_wayland.h', [ 'VK_KHR_wayland_surface' ], commonSuppressExtensions ],
|
[ 'vulkan_wayland.h', [ 'VK_KHR_wayland_surface' ], commonSuppressExtensions ],
|
||||||
[ 'vulkan_win32.h', [ 'VK_.*_win32(|_.*)', 'VK_EXT_full_screen_exclusive' ],
|
[ 'vulkan_win32.h', [ 'VK_.*_win32(|_.*)', 'VK_.*_winrt(|_.*)', 'VK_EXT_full_screen_exclusive' ],
|
||||||
commonSuppressExtensions +
|
commonSuppressExtensions +
|
||||||
[ 'VK_KHR_external_semaphore',
|
[ 'VK_KHR_external_semaphore',
|
||||||
'VK_KHR_external_memory_capabilities',
|
'VK_KHR_external_memory_capabilities',
|
||||||
@ -425,6 +451,7 @@ def makeGenOpts(args):
|
|||||||
directory = directory,
|
directory = directory,
|
||||||
genpath = None,
|
genpath = None,
|
||||||
apiname = defaultAPIName,
|
apiname = defaultAPIName,
|
||||||
|
mergeApiNames = mergeApiNames,
|
||||||
profile = None,
|
profile = None,
|
||||||
versions = featuresPat,
|
versions = featuresPat,
|
||||||
emitversions = None,
|
emitversions = None,
|
||||||
@ -466,6 +493,7 @@ def makeGenOpts(args):
|
|||||||
directory = directory,
|
directory = directory,
|
||||||
genpath = None,
|
genpath = None,
|
||||||
apiname = defaultAPIName,
|
apiname = defaultAPIName,
|
||||||
|
mergeApiNames = mergeApiNames,
|
||||||
profile = None,
|
profile = None,
|
||||||
versions = featuresPat,
|
versions = featuresPat,
|
||||||
emitversions = featuresPat,
|
emitversions = featuresPat,
|
||||||
@ -582,10 +610,11 @@ def makeGenOpts(args):
|
|||||||
directory = directory,
|
directory = directory,
|
||||||
genpath = None,
|
genpath = None,
|
||||||
apiname = defaultAPIName,
|
apiname = defaultAPIName,
|
||||||
|
mergeApiNames = mergeApiNames,
|
||||||
profile = None,
|
profile = None,
|
||||||
versions = None,
|
versions = None,
|
||||||
emitversions = None,
|
emitversions = None,
|
||||||
defaultExtensions = None,
|
defaultExtensions = defaultAPIName,
|
||||||
addExtensions = addExtensionRE,
|
addExtensions = addExtensionRE,
|
||||||
removeExtensions = None,
|
removeExtensions = None,
|
||||||
emitExtensions = emitExtensionRE,
|
emitExtensions = emitExtensionRE,
|
||||||
@ -707,6 +736,12 @@ def genTarget(args):
|
|||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
parser = argparse.ArgumentParser()
|
parser = argparse.ArgumentParser()
|
||||||
|
|
||||||
|
parser.add_argument('-apiname', action='store',
|
||||||
|
default=None,
|
||||||
|
help='Specify API to generate (defaults to repository-specific conventions object value)')
|
||||||
|
parser.add_argument('-mergeApiNames', action='store',
|
||||||
|
default=None,
|
||||||
|
help='Specify a comma separated list of APIs to merge into the target API')
|
||||||
parser.add_argument('-defaultExtensions', action='store',
|
parser.add_argument('-defaultExtensions', action='store',
|
||||||
default=APIConventions().xml_api_name,
|
default=APIConventions().xml_api_name,
|
||||||
help='Specify a single class of extensions to add to targets')
|
help='Specify a single class of extensions to add to targets')
|
||||||
|
354
registry/parse_dependency.py
Normal file
354
registry/parse_dependency.py
Normal file
@ -0,0 +1,354 @@
|
|||||||
|
#!/usr/bin/python3
|
||||||
|
|
||||||
|
# Copyright 2022-2023 The Khronos Group Inc.
|
||||||
|
# Copyright 2003-2019 Paul McGuire
|
||||||
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
|
# apirequirements.py - parse 'depends' expressions in API XML
|
||||||
|
# Supported methods:
|
||||||
|
# dependency - the expression string
|
||||||
|
#
|
||||||
|
# evaluateDependency(dependency, isSupported) evaluates the expression,
|
||||||
|
# returning a boolean result. isSupported takes an extension or version name
|
||||||
|
# string and returns a boolean.
|
||||||
|
#
|
||||||
|
# dependencyLanguage(dependency) returns an English string equivalent
|
||||||
|
# to the expression, suitable for header file comments.
|
||||||
|
#
|
||||||
|
# dependencyNames(dependency) returns a set of the extension and
|
||||||
|
# version names in the expression.
|
||||||
|
#
|
||||||
|
# dependencyMarkup(dependency) returns a string containing asciidoctor
|
||||||
|
# markup for English equivalent to the expression, suitable for extension
|
||||||
|
# appendices.
|
||||||
|
#
|
||||||
|
# All may throw a ParseException if the expression cannot be parsed or is
|
||||||
|
# not completely consumed by parsing.
|
||||||
|
|
||||||
|
# Supported expressions at present:
|
||||||
|
# - extension names
|
||||||
|
# - '+' as AND connector
|
||||||
|
# - ',' as OR connector
|
||||||
|
# - parenthesization for grouping
|
||||||
|
|
||||||
|
# Based on https://github.com/pyparsing/pyparsing/blob/master/examples/fourFn.py
|
||||||
|
|
||||||
|
from pyparsing import (
|
||||||
|
Literal,
|
||||||
|
Word,
|
||||||
|
Group,
|
||||||
|
Forward,
|
||||||
|
alphas,
|
||||||
|
alphanums,
|
||||||
|
Regex,
|
||||||
|
ParseException,
|
||||||
|
CaselessKeyword,
|
||||||
|
Suppress,
|
||||||
|
delimitedList,
|
||||||
|
infixNotation,
|
||||||
|
)
|
||||||
|
import math
|
||||||
|
import operator
|
||||||
|
import pyparsing as pp
|
||||||
|
import re
|
||||||
|
|
||||||
|
def nameMarkup(name):
|
||||||
|
"""Returns asciidoc markup to generate a link to an API version or
|
||||||
|
extension anchor.
|
||||||
|
|
||||||
|
- name - version or extension name"""
|
||||||
|
|
||||||
|
# Could use ApiConventions.is_api_version_name, but that does not split
|
||||||
|
# out the major/minor version numbers.
|
||||||
|
match = re.search("[A-Z]+_VERSION_([0-9]+)_([0-9]+)", name)
|
||||||
|
if match is not None:
|
||||||
|
major = match.group(1)
|
||||||
|
minor = match.group(2)
|
||||||
|
version = major + '.' + minor
|
||||||
|
return f'<<versions-{major}.{minor}, Version {version}>>'
|
||||||
|
else:
|
||||||
|
return 'apiext:' + name
|
||||||
|
|
||||||
|
exprStack = []
|
||||||
|
|
||||||
|
def push_first(toks):
|
||||||
|
"""Push a token on the global stack
|
||||||
|
|
||||||
|
- toks - first element is the token to push"""
|
||||||
|
|
||||||
|
exprStack.append(toks[0])
|
||||||
|
|
||||||
|
# An identifier (version or extension name)
|
||||||
|
dependencyIdent = Word(alphanums + '_')
|
||||||
|
|
||||||
|
# Infix expression for depends expressions
|
||||||
|
dependencyExpr = pp.infixNotation(dependencyIdent,
|
||||||
|
[ (pp.oneOf(', +'), 2, pp.opAssoc.LEFT), ])
|
||||||
|
|
||||||
|
# BNF grammar for depends expressions
|
||||||
|
_bnf = None
|
||||||
|
def dependencyBNF():
|
||||||
|
"""
|
||||||
|
boolop :: '+' | ','
|
||||||
|
extname :: Char(alphas)
|
||||||
|
atom :: extname | '(' expr ')'
|
||||||
|
expr :: atom [ boolop atom ]*
|
||||||
|
"""
|
||||||
|
global _bnf
|
||||||
|
if _bnf is None:
|
||||||
|
and_, or_ = map(Literal, '+,')
|
||||||
|
lpar, rpar = map(Suppress, '()')
|
||||||
|
boolop = and_ | or_
|
||||||
|
|
||||||
|
expr = Forward()
|
||||||
|
expr_list = delimitedList(Group(expr))
|
||||||
|
atom = (
|
||||||
|
boolop[...]
|
||||||
|
+ (
|
||||||
|
(dependencyIdent).setParseAction(push_first)
|
||||||
|
| Group(lpar + expr + rpar)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
expr <<= atom + (boolop + atom).setParseAction(push_first)[...]
|
||||||
|
_bnf = expr
|
||||||
|
return _bnf
|
||||||
|
|
||||||
|
|
||||||
|
# map operator symbols to corresponding arithmetic operations
|
||||||
|
_opn = {
|
||||||
|
'+': operator.and_,
|
||||||
|
',': operator.or_,
|
||||||
|
}
|
||||||
|
|
||||||
|
# map operator symbols to corresponding words
|
||||||
|
_opname = {
|
||||||
|
'+': 'and',
|
||||||
|
',': 'or',
|
||||||
|
}
|
||||||
|
|
||||||
|
def evaluateStack(stack, isSupported):
|
||||||
|
"""Evaluate an expression stack, returning a boolean result.
|
||||||
|
|
||||||
|
- stack - the stack
|
||||||
|
- isSupported - function taking a version or extension name string and
|
||||||
|
returning True or False if that name is supported or not."""
|
||||||
|
|
||||||
|
op, num_args = stack.pop(), 0
|
||||||
|
if isinstance(op, tuple):
|
||||||
|
op, num_args = op
|
||||||
|
|
||||||
|
if op in '+,':
|
||||||
|
# Note: operands are pushed onto the stack in reverse order
|
||||||
|
op2 = evaluateStack(stack, isSupported)
|
||||||
|
op1 = evaluateStack(stack, isSupported)
|
||||||
|
return _opn[op](op1, op2)
|
||||||
|
elif op[0].isalpha():
|
||||||
|
return isSupported(op)
|
||||||
|
else:
|
||||||
|
raise Exception(f'invalid op: {op}')
|
||||||
|
|
||||||
|
def evaluateDependency(dependency, isSupported):
|
||||||
|
"""Evaluate a dependency expression, returning a boolean result.
|
||||||
|
|
||||||
|
- dependency - the expression
|
||||||
|
- isSupported - function taking a version or extension name string and
|
||||||
|
returning True or False if that name is supported or not."""
|
||||||
|
|
||||||
|
global exprStack
|
||||||
|
exprStack = []
|
||||||
|
results = dependencyBNF().parseString(dependency, parseAll=True)
|
||||||
|
val = evaluateStack(exprStack[:], isSupported)
|
||||||
|
return val
|
||||||
|
|
||||||
|
def evalDependencyLanguage(stack, specmacros):
|
||||||
|
"""Evaluate an expression stack, returning an English equivalent
|
||||||
|
|
||||||
|
- stack - the stack
|
||||||
|
- specmacros - if True, prepare the language for spec inclusion"""
|
||||||
|
|
||||||
|
op, num_args = stack.pop(), 0
|
||||||
|
if isinstance(op, tuple):
|
||||||
|
op, num_args = op
|
||||||
|
if op in '+,':
|
||||||
|
# Could parenthesize, not needed yet
|
||||||
|
rhs = evalDependencyLanguage(stack, specmacros)
|
||||||
|
return evalDependencyLanguage(stack, specmacros) + f' {_opname[op]} ' + rhs
|
||||||
|
elif op[0].isalpha():
|
||||||
|
# This is an extension or feature name
|
||||||
|
if specmacros:
|
||||||
|
return nameMarkup(op)
|
||||||
|
else:
|
||||||
|
return op
|
||||||
|
else:
|
||||||
|
raise Exception(f'invalid op: {op}')
|
||||||
|
|
||||||
|
def dependencyLanguage(dependency, specmacros = False):
|
||||||
|
"""Return an API dependency expression translated to a form suitable for
|
||||||
|
asciidoctor conditionals or header file comments.
|
||||||
|
|
||||||
|
- dependency - the expression
|
||||||
|
- specmacros - if False, return a string that can be used as an
|
||||||
|
asciidoctor conditional.
|
||||||
|
If True, return a string suitable for spec inclusion with macros and
|
||||||
|
xrefs included."""
|
||||||
|
|
||||||
|
global exprStack
|
||||||
|
exprStack = []
|
||||||
|
results = dependencyBNF().parseString(dependency, parseAll=True)
|
||||||
|
return evalDependencyLanguage(exprStack, specmacros)
|
||||||
|
|
||||||
|
def evalDependencyNames(stack):
|
||||||
|
"""Evaluate an expression stack, returning the set of extension and
|
||||||
|
feature names used in the expression.
|
||||||
|
|
||||||
|
- stack - the stack"""
|
||||||
|
|
||||||
|
op, num_args = stack.pop(), 0
|
||||||
|
if isinstance(op, tuple):
|
||||||
|
op, num_args = op
|
||||||
|
if op in '+,':
|
||||||
|
# Do not evaluate the operation. We only care about the names.
|
||||||
|
return evalDependencyNames(stack) | evalDependencyNames(stack)
|
||||||
|
elif op[0].isalpha():
|
||||||
|
return { op }
|
||||||
|
else:
|
||||||
|
raise Exception(f'invalid op: {op}')
|
||||||
|
|
||||||
|
def dependencyNames(dependency):
|
||||||
|
"""Return a set of the extension and version names in an API dependency
|
||||||
|
expression. Used when determining transitive dependencies for spec
|
||||||
|
generation with specific extensions included.
|
||||||
|
|
||||||
|
- dependency - the expression"""
|
||||||
|
|
||||||
|
global exprStack
|
||||||
|
exprStack = []
|
||||||
|
results = dependencyBNF().parseString(dependency, parseAll=True)
|
||||||
|
# print(f'names(): stack = {exprStack}')
|
||||||
|
return evalDependencyNames(exprStack)
|
||||||
|
|
||||||
|
def markupTraverse(expr, level = 0, root = True):
|
||||||
|
"""Recursively process a dependency in infix form, transforming it into
|
||||||
|
asciidoctor markup with expression nesting indicated by indentation
|
||||||
|
level.
|
||||||
|
|
||||||
|
- expr - expression to process
|
||||||
|
- level - indentation level to render expression at
|
||||||
|
- root - True only on initial call"""
|
||||||
|
|
||||||
|
if level > 0:
|
||||||
|
prefix = '{nbsp}{nbsp}' * level * 2 + ' '
|
||||||
|
else:
|
||||||
|
prefix = ''
|
||||||
|
str = ''
|
||||||
|
|
||||||
|
for elem in expr:
|
||||||
|
if isinstance(elem, pp.ParseResults):
|
||||||
|
if not root:
|
||||||
|
nextlevel = level + 1
|
||||||
|
else:
|
||||||
|
# Do not indent the outer expression
|
||||||
|
nextlevel = level
|
||||||
|
|
||||||
|
str = str + markupTraverse(elem, level = nextlevel, root = False)
|
||||||
|
elif elem in ('+', ','):
|
||||||
|
str = str + f'{prefix}{_opname[elem]} +\n'
|
||||||
|
else:
|
||||||
|
str = str + f'{prefix}{nameMarkup(elem)} +\n'
|
||||||
|
|
||||||
|
return str
|
||||||
|
|
||||||
|
def dependencyMarkup(dependency):
|
||||||
|
"""Return asciidoctor markup for a human-readable equivalent of an API
|
||||||
|
dependency expression, suitable for use in extension appendix
|
||||||
|
metadata.
|
||||||
|
|
||||||
|
- dependency - the expression"""
|
||||||
|
|
||||||
|
parsed = dependencyExpr.parseString(dependency)
|
||||||
|
return markupTraverse(parsed)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
|
||||||
|
termdict = {
|
||||||
|
'VK_VERSION_1_1' : True,
|
||||||
|
'false' : False,
|
||||||
|
'true' : True,
|
||||||
|
}
|
||||||
|
termSupported = lambda name: name in termdict and termdict[name]
|
||||||
|
|
||||||
|
def test(dependency, expected):
|
||||||
|
val = False
|
||||||
|
try:
|
||||||
|
val = evaluateDependency(dependency, termSupported)
|
||||||
|
except ParseException as pe:
|
||||||
|
print(dependency, f'failed parse: {dependency}')
|
||||||
|
except Exception as e:
|
||||||
|
print(dependency, f'failed eval: {dependency}')
|
||||||
|
|
||||||
|
if val == expected:
|
||||||
|
print(f'{dependency} = {val} (as expected)')
|
||||||
|
else:
|
||||||
|
print(f'{dependency} ERROR: {val} != {expected}')
|
||||||
|
|
||||||
|
# Verify expressions are evaluated left-to-right
|
||||||
|
|
||||||
|
test('false,false+false', False)
|
||||||
|
test('false,false+true', False)
|
||||||
|
test('false,true+false', False)
|
||||||
|
test('false,true+true', True)
|
||||||
|
test('true,false+false', False)
|
||||||
|
test('true,false+true', True)
|
||||||
|
test('true,true+false', False)
|
||||||
|
test('true,true+true', True)
|
||||||
|
|
||||||
|
test('false,(false+false)', False)
|
||||||
|
test('false,(false+true)', False)
|
||||||
|
test('false,(true+false)', False)
|
||||||
|
test('false,(true+true)', True)
|
||||||
|
test('true,(false+false)', True)
|
||||||
|
test('true,(false+true)', True)
|
||||||
|
test('true,(true+false)', True)
|
||||||
|
test('true,(true+true)', True)
|
||||||
|
|
||||||
|
|
||||||
|
test('false+false,false', False)
|
||||||
|
test('false+false,true', True)
|
||||||
|
test('false+true,false', False)
|
||||||
|
test('false+true,true', True)
|
||||||
|
test('true+false,false', False)
|
||||||
|
test('true+false,true', True)
|
||||||
|
test('true+true,false', True)
|
||||||
|
test('true+true,true', True)
|
||||||
|
|
||||||
|
test('false+(false,false)', False)
|
||||||
|
test('false+(false,true)', False)
|
||||||
|
test('false+(true,false)', False)
|
||||||
|
test('false+(true,true)', False)
|
||||||
|
test('true+(false,false)', False)
|
||||||
|
test('true+(false,true)', True)
|
||||||
|
test('true+(true,false)', True)
|
||||||
|
test('true+(true,true)', True)
|
||||||
|
|
||||||
|
|
||||||
|
#test('VK_VERSION_1_1+(false,true)', True)
|
||||||
|
#test('true', True)
|
||||||
|
#test('(true)', True)
|
||||||
|
#test('false,false', False)
|
||||||
|
#test('false,true', True)
|
||||||
|
#test('false+true', False)
|
||||||
|
#test('true+true', True)
|
||||||
|
|
||||||
|
# Check formatting
|
||||||
|
for dependency in [
|
||||||
|
#'true',
|
||||||
|
#'true+true+false',
|
||||||
|
'true+(true+false),(false,true)',
|
||||||
|
'true+((true+false),(false,true))',
|
||||||
|
#'VK_VERSION_1_1+(true,false)',
|
||||||
|
]:
|
||||||
|
print(f'expr = {dependency}\n{dependencyMarkup(dependency)}')
|
||||||
|
print(f' language = {dependencyLanguage(dependency)}')
|
||||||
|
print(f' names = {dependencyNames(dependency)}')
|
||||||
|
print(f' value = {evaluateDependency(dependency, termSupported)}')
|
381
registry/profiles/VP_KHR_roadmap_2022.json
Normal file
381
registry/profiles/VP_KHR_roadmap_2022.json
Normal file
@ -0,0 +1,381 @@
|
|||||||
|
{
|
||||||
|
"$schema": "https://schema.khronos.org/vulkan/profiles-0.8.1-204.json#",
|
||||||
|
"capabilities": {
|
||||||
|
"vulkan10requirements": {
|
||||||
|
"features": {
|
||||||
|
"VkPhysicalDeviceFeatures": {
|
||||||
|
"robustBufferAccess": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"vulkan10requirements_roadmap2022": {
|
||||||
|
"features": {
|
||||||
|
"VkPhysicalDeviceFeatures": {
|
||||||
|
"fullDrawIndexUint32": true,
|
||||||
|
"imageCubeArray": true,
|
||||||
|
"independentBlend": true,
|
||||||
|
"sampleRateShading": true,
|
||||||
|
"drawIndirectFirstInstance": true,
|
||||||
|
"depthClamp": true,
|
||||||
|
"depthBiasClamp": true,
|
||||||
|
"samplerAnisotropy": true,
|
||||||
|
"occlusionQueryPrecise": true,
|
||||||
|
"fragmentStoresAndAtomics": true,
|
||||||
|
"shaderStorageImageExtendedFormats": true,
|
||||||
|
"shaderUniformBufferArrayDynamicIndexing": true,
|
||||||
|
"shaderSampledImageArrayDynamicIndexing": true,
|
||||||
|
"shaderStorageBufferArrayDynamicIndexing": true,
|
||||||
|
"shaderStorageImageArrayDynamicIndexing": true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"properties": {
|
||||||
|
"VkPhysicalDeviceProperties": {
|
||||||
|
"limits": {
|
||||||
|
"maxImageDimension1D": 8192,
|
||||||
|
"maxImageDimension2D": 8192,
|
||||||
|
"maxImageDimensionCube": 8192,
|
||||||
|
"maxImageArrayLayers": 2048,
|
||||||
|
"maxUniformBufferRange": 65536,
|
||||||
|
"bufferImageGranularity": 4096,
|
||||||
|
"maxPerStageDescriptorSamplers": 64,
|
||||||
|
"maxPerStageDescriptorUniformBuffers": 15,
|
||||||
|
"maxPerStageDescriptorStorageBuffers": 30,
|
||||||
|
"maxPerStageDescriptorSampledImages": 200,
|
||||||
|
"maxPerStageDescriptorStorageImages": 16,
|
||||||
|
"maxPerStageResources": 200,
|
||||||
|
"maxDescriptorSetSamplers": 576,
|
||||||
|
"maxDescriptorSetUniformBuffers": 90,
|
||||||
|
"maxDescriptorSetStorageBuffers": 96,
|
||||||
|
"maxDescriptorSetSampledImages": 1800,
|
||||||
|
"maxDescriptorSetStorageImages": 144,
|
||||||
|
"maxFragmentCombinedOutputResources": 16,
|
||||||
|
"maxComputeWorkGroupInvocations": 256,
|
||||||
|
"maxComputeWorkGroupSize": [ 256, 256, 64 ],
|
||||||
|
"subTexelPrecisionBits": 8,
|
||||||
|
"mipmapPrecisionBits": 6,
|
||||||
|
"maxSamplerLodBias": 14,
|
||||||
|
"standardSampleLocations": true,
|
||||||
|
"maxColorAttachments": 7
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"vulkan10optionals_roadmap2022": {
|
||||||
|
"features": {
|
||||||
|
"VkPhysicalDeviceFeatures": {
|
||||||
|
"largePoints": true,
|
||||||
|
"wideLines": true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"properties": {
|
||||||
|
"VkPhysicalDeviceProperties": {
|
||||||
|
"limits": {
|
||||||
|
"pointSizeGranularity": 0.125,
|
||||||
|
"lineWidthGranularity": 0.5
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"vulkan11requirements": {
|
||||||
|
"features": {
|
||||||
|
"VkPhysicalDeviceVulkan11Features": {
|
||||||
|
"multiview": true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"properties": {
|
||||||
|
"VkPhysicalDeviceVulkan11Properties": {
|
||||||
|
"maxMultiviewViewCount": 6,
|
||||||
|
"maxMultiviewInstanceIndex": 134217727
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"vulkan11requirements_roadmap2022": {
|
||||||
|
"features": {
|
||||||
|
"VkPhysicalDeviceVulkan11Features": {
|
||||||
|
"samplerYcbcrConversion": true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"properties": {
|
||||||
|
"VkPhysicalDeviceVulkan11Properties": {
|
||||||
|
"subgroupSize": 4,
|
||||||
|
"subgroupSupportedStages": [ "VK_SHADER_STAGE_COMPUTE_BIT", "VK_SHADER_STAGE_FRAGMENT_BIT" ],
|
||||||
|
"subgroupSupportedOperations": [ "VK_SUBGROUP_FEATURE_BASIC_BIT", "VK_SUBGROUP_FEATURE_VOTE_BIT", "VK_SUBGROUP_FEATURE_ARITHMETIC_BIT", "VK_SUBGROUP_FEATURE_BALLOT_BIT", "VK_SUBGROUP_FEATURE_SHUFFLE_BIT", "VK_SUBGROUP_FEATURE_SHUFFLE_RELATIVE_BIT", "VK_SUBGROUP_FEATURE_QUAD_BIT" ]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"vulkan12requirements": {
|
||||||
|
"features": {
|
||||||
|
"VkPhysicalDeviceVulkan12Features": {
|
||||||
|
"uniformBufferStandardLayout": true,
|
||||||
|
"subgroupBroadcastDynamicId": true,
|
||||||
|
"imagelessFramebuffer": true,
|
||||||
|
"separateDepthStencilLayouts": true,
|
||||||
|
"hostQueryReset": true,
|
||||||
|
"timelineSemaphore": true,
|
||||||
|
"shaderSubgroupExtendedTypes": true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"properties": {
|
||||||
|
"VkPhysicalDeviceVulkan12Properties": {
|
||||||
|
"maxTimelineSemaphoreValueDifference": 2147483647
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"vulkan12requirements_roadmap2022": {
|
||||||
|
"features": {
|
||||||
|
"VkPhysicalDeviceVulkan12Features": {
|
||||||
|
"samplerMirrorClampToEdge": true,
|
||||||
|
"descriptorIndexing": true,
|
||||||
|
"shaderUniformTexelBufferArrayDynamicIndexing": true,
|
||||||
|
"shaderStorageTexelBufferArrayDynamicIndexing": true,
|
||||||
|
"shaderUniformBufferArrayNonUniformIndexing": true,
|
||||||
|
"shaderSampledImageArrayNonUniformIndexing": true,
|
||||||
|
"shaderStorageBufferArrayNonUniformIndexing": true,
|
||||||
|
"shaderStorageImageArrayNonUniformIndexing": true,
|
||||||
|
"shaderUniformTexelBufferArrayNonUniformIndexing": true,
|
||||||
|
"shaderStorageTexelBufferArrayNonUniformIndexing": true,
|
||||||
|
"descriptorBindingSampledImageUpdateAfterBind": true,
|
||||||
|
"descriptorBindingStorageImageUpdateAfterBind": true,
|
||||||
|
"descriptorBindingStorageBufferUpdateAfterBind": true,
|
||||||
|
"descriptorBindingUniformTexelBufferUpdateAfterBind": true,
|
||||||
|
"descriptorBindingStorageTexelBufferUpdateAfterBind": true,
|
||||||
|
"descriptorBindingUpdateUnusedWhilePending": true,
|
||||||
|
"descriptorBindingPartiallyBound": true,
|
||||||
|
"descriptorBindingVariableDescriptorCount": true,
|
||||||
|
"runtimeDescriptorArray": true,
|
||||||
|
"scalarBlockLayout": true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"properties": {
|
||||||
|
"VkPhysicalDeviceVulkan12Properties": {
|
||||||
|
"shaderSignedZeroInfNanPreserveFloat16": true,
|
||||||
|
"shaderSignedZeroInfNanPreserveFloat32": true,
|
||||||
|
"maxPerStageDescriptorUpdateAfterBindSamplers": 500000,
|
||||||
|
"maxPerStageDescriptorUpdateAfterBindUniformBuffers": 12,
|
||||||
|
"maxPerStageDescriptorUpdateAfterBindStorageBuffers": 500000,
|
||||||
|
"maxPerStageDescriptorUpdateAfterBindSampledImages": 500000,
|
||||||
|
"maxPerStageDescriptorUpdateAfterBindStorageImages": 500000,
|
||||||
|
"maxPerStageDescriptorUpdateAfterBindInputAttachments": 7,
|
||||||
|
"maxPerStageUpdateAfterBindResources": 500000,
|
||||||
|
"maxDescriptorSetUpdateAfterBindSamplers": 500000,
|
||||||
|
"maxDescriptorSetUpdateAfterBindUniformBuffers": 72,
|
||||||
|
"maxDescriptorSetUpdateAfterBindUniformBuffersDynamic": 8,
|
||||||
|
"maxDescriptorSetUpdateAfterBindStorageBuffers": 500000,
|
||||||
|
"maxDescriptorSetUpdateAfterBindStorageBuffersDynamic": 4,
|
||||||
|
"maxDescriptorSetUpdateAfterBindSampledImages": 500000,
|
||||||
|
"maxDescriptorSetUpdateAfterBindStorageImages": 500000,
|
||||||
|
"maxDescriptorSetUpdateAfterBindInputAttachments": 7
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"vulkan13requirements": {
|
||||||
|
"features": {
|
||||||
|
"VkPhysicalDeviceVulkan12Features": {
|
||||||
|
"vulkanMemoryModel": true,
|
||||||
|
"vulkanMemoryModelDeviceScope": true,
|
||||||
|
"bufferDeviceAddress": true
|
||||||
|
},
|
||||||
|
"VkPhysicalDeviceVulkan13Features": {
|
||||||
|
"robustImageAccess": true,
|
||||||
|
"shaderTerminateInvocation": true,
|
||||||
|
"shaderZeroInitializeWorkgroupMemory": true,
|
||||||
|
"synchronization2": true,
|
||||||
|
"shaderIntegerDotProduct": true,
|
||||||
|
"maintenance4": true,
|
||||||
|
"pipelineCreationCacheControl": true,
|
||||||
|
"subgroupSizeControl": true,
|
||||||
|
"computeFullSubgroups": true,
|
||||||
|
"shaderDemoteToHelperInvocation": true,
|
||||||
|
"inlineUniformBlock": true,
|
||||||
|
"dynamicRendering": true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"properties": {
|
||||||
|
"VkPhysicalDeviceVulkan13Properties": {
|
||||||
|
"maxBufferSize": 1073741824,
|
||||||
|
"maxInlineUniformBlockSize": 256,
|
||||||
|
"maxPerStageDescriptorInlineUniformBlocks": 4,
|
||||||
|
"maxPerStageDescriptorUpdateAfterBindInlineUniformBlocks": 4,
|
||||||
|
"maxDescriptorSetInlineUniformBlocks": 4,
|
||||||
|
"maxDescriptorSetUpdateAfterBindInlineUniformBlocks": 4,
|
||||||
|
"maxInlineUniformTotalSize": 256
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"vulkan13requirements_1_2": {
|
||||||
|
"extensions": {
|
||||||
|
"VK_EXT_image_robustness": 1,
|
||||||
|
"VK_KHR_shader_non_semantic_info": 1,
|
||||||
|
"VK_KHR_shader_terminate_invocation": 1,
|
||||||
|
"VK_KHR_format_feature_flags2": 1,
|
||||||
|
"VK_KHR_zero_initialize_workgroup_memory": 1,
|
||||||
|
"VK_KHR_synchronization2": 1,
|
||||||
|
"VK_KHR_shader_integer_dot_product": 1,
|
||||||
|
"VK_KHR_maintenance4": 1,
|
||||||
|
"VK_EXT_4444_formats": 1,
|
||||||
|
"VK_EXT_extended_dynamic_state": 1,
|
||||||
|
"VK_EXT_extended_dynamic_state2": 1,
|
||||||
|
"VK_EXT_pipeline_creation_cache_control": 1,
|
||||||
|
"VK_EXT_subgroup_size_control": 1,
|
||||||
|
"VK_EXT_shader_demote_to_helper_invocation": 1,
|
||||||
|
"VK_EXT_inline_uniform_block": 1,
|
||||||
|
"VK_EXT_pipeline_creation_feedback": 1,
|
||||||
|
"VK_EXT_texel_buffer_alignment": 1,
|
||||||
|
"VK_EXT_ycbcr_2plane_444_formats": 1,
|
||||||
|
"VK_EXT_texture_compression_astc_hdr": 1,
|
||||||
|
"VK_EXT_tooling_info": 1,
|
||||||
|
"VK_EXT_private_data": 1,
|
||||||
|
"VK_KHR_dynamic_rendering": 1
|
||||||
|
},
|
||||||
|
"features": {
|
||||||
|
"VkPhysicalDeviceVulkan12Features": {
|
||||||
|
"vulkanMemoryModel": true,
|
||||||
|
"vulkanMemoryModelDeviceScope": true,
|
||||||
|
"vulkanMemoryModelAvailabilityVisibilityChains": true,
|
||||||
|
"bufferDeviceAddress": true
|
||||||
|
},
|
||||||
|
"VkPhysicalDeviceImageRobustnessFeaturesEXT": {
|
||||||
|
"robustImageAccess": true
|
||||||
|
},
|
||||||
|
"VkPhysicalDeviceShaderTerminateInvocationFeaturesKHR": {
|
||||||
|
"shaderTerminateInvocation": true
|
||||||
|
},
|
||||||
|
"VkPhysicalDeviceZeroInitializeWorkgroupMemoryFeaturesKHR": {
|
||||||
|
"shaderZeroInitializeWorkgroupMemory": true
|
||||||
|
},
|
||||||
|
"VkPhysicalDeviceSynchronization2FeaturesKHR": {
|
||||||
|
"synchronization2": true
|
||||||
|
},
|
||||||
|
"VkPhysicalDeviceShaderIntegerDotProductFeaturesKHR": {
|
||||||
|
"shaderIntegerDotProduct": true
|
||||||
|
},
|
||||||
|
"VkPhysicalDeviceMaintenance4FeaturesKHR": {
|
||||||
|
"maintenance4": true
|
||||||
|
},
|
||||||
|
"VkPhysicalDevicePipelineCreationCacheControlFeaturesEXT": {
|
||||||
|
"pipelineCreationCacheControl": true
|
||||||
|
},
|
||||||
|
"VkPhysicalDeviceSubgroupSizeControlFeaturesEXT": {
|
||||||
|
"subgroupSizeControl": true,
|
||||||
|
"computeFullSubgroups": true
|
||||||
|
},
|
||||||
|
"VkPhysicalDeviceShaderDemoteToHelperInvocationFeaturesEXT": {
|
||||||
|
"shaderDemoteToHelperInvocation": true
|
||||||
|
},
|
||||||
|
"VkPhysicalDeviceInlineUniformBlockFeaturesEXT": {
|
||||||
|
"inlineUniformBlock": true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"properties": {
|
||||||
|
"VkPhysicalDeviceMaintenance4PropertiesKHR": {
|
||||||
|
"maxBufferSize": 1073741824
|
||||||
|
},
|
||||||
|
"VkPhysicalDeviceInlineUniformBlockPropertiesEXT": {
|
||||||
|
"maxInlineUniformBlockSize": 256,
|
||||||
|
"maxPerStageDescriptorInlineUniformBlocks": 4,
|
||||||
|
"maxPerStageDescriptorUpdateAfterBindInlineUniformBlocks": 4,
|
||||||
|
"maxDescriptorSetInlineUniformBlocks": 4,
|
||||||
|
"maxDescriptorSetUpdateAfterBindInlineUniformBlocks": 4
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"vulkan13requirements_roadmap2022": {
|
||||||
|
"extensions": {
|
||||||
|
"VK_KHR_global_priority": 1
|
||||||
|
},
|
||||||
|
"features": {
|
||||||
|
"VkPhysicalDeviceVulkan13Features": {
|
||||||
|
"descriptorBindingInlineUniformBlockUpdateAfterBind": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"vulkan13requirements_roadmap2022_1_2": {
|
||||||
|
"extensions": {
|
||||||
|
"VK_EXT_global_priority": 1,
|
||||||
|
"VK_EXT_inline_uniform_block": 1
|
||||||
|
},
|
||||||
|
"features": {
|
||||||
|
"VkPhysicalDeviceInlineUniformBlockFeaturesEXT": {
|
||||||
|
"descriptorBindingInlineUniformBlockUpdateAfterBind": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"profiles": {
|
||||||
|
"VP_KHR_roadmap_2022": {
|
||||||
|
"version": 1,
|
||||||
|
"api-version": "1.3.204",
|
||||||
|
"label": "Khronos Vulkan Roadmap 2022 profile",
|
||||||
|
"description": "This roadmap profile is intended to be supported by newer devices shipping in 2022 across mainstream smartphone, tablet, laptops, console and desktop devices.",
|
||||||
|
"contributors": {
|
||||||
|
"Tobias Hector": {
|
||||||
|
"company": "AMD",
|
||||||
|
"email": "tobias.hector@amd.com",
|
||||||
|
"contact": true
|
||||||
|
},
|
||||||
|
"Christophe Riccio": {
|
||||||
|
"company": "LunarG",
|
||||||
|
"email": "christophe@lunarg.com",
|
||||||
|
"contact": true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"history": [
|
||||||
|
{
|
||||||
|
"revision": 7,
|
||||||
|
"date": "2022-11-16",
|
||||||
|
"author": "Christophe Riccio",
|
||||||
|
"comment": "Fix wideLines and largePoints that are optionals"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"revision": 6,
|
||||||
|
"date": "2022-11-02",
|
||||||
|
"author": "Christophe Riccio",
|
||||||
|
"comment": "Fix roadmap 2022 maxInlineUniformTotalSize limit, 256 instead of 4"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"revision": 5,
|
||||||
|
"date": "2022-05-02",
|
||||||
|
"author": "Christophe Riccio",
|
||||||
|
"comment": "Add missing dynamicRendering that is a Vulkan 1.3 requirement"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"revision": 4,
|
||||||
|
"date": "2022-03-08",
|
||||||
|
"author": "Christophe Riccio",
|
||||||
|
"comment": "Refactor requirements per Vulkan API version"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"revision": 3,
|
||||||
|
"date": "2022-03-08",
|
||||||
|
"author": "Christophe Riccio",
|
||||||
|
"comment": "Fix Vulkan 1.3.204 API version requirement"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"revision": 2,
|
||||||
|
"date": "2022-01-03",
|
||||||
|
"author": "Christophe Riccio",
|
||||||
|
"comment": "Rebase against Vulkan 1.3.203 revision"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"revision": 1,
|
||||||
|
"date": "2021-12-08",
|
||||||
|
"author": "Christophe Riccio",
|
||||||
|
"comment": "Initial revision"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"capabilities": [
|
||||||
|
"vulkan10requirements",
|
||||||
|
"vulkan10requirements_roadmap2022",
|
||||||
|
"vulkan11requirements",
|
||||||
|
"vulkan11requirements_roadmap2022",
|
||||||
|
"vulkan12requirements",
|
||||||
|
"vulkan12requirements_roadmap2022",
|
||||||
|
"vulkan13requirements",
|
||||||
|
"vulkan13requirements_roadmap2022"
|
||||||
|
],
|
||||||
|
"optionals": [
|
||||||
|
"vulkan10optionals_roadmap2022"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
138
registry/reg.py
138
registry/reg.py
@ -1,6 +1,6 @@
|
|||||||
#!/usr/bin/python3 -i
|
#!/usr/bin/python3 -i
|
||||||
#
|
#
|
||||||
# Copyright 2013-2022 The Khronos Group Inc.
|
# Copyright 2013-2023 The Khronos Group Inc.
|
||||||
#
|
#
|
||||||
# SPDX-License-Identifier: Apache-2.0
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
@ -88,6 +88,82 @@ def matchAPIProfile(api, profile, elem):
|
|||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
||||||
|
def mergeAPIs(tree, fromApiNames, toApiName):
|
||||||
|
"""Merge multiple APIs using the precedence order specified in apiNames.
|
||||||
|
Also deletes <remove> elements.
|
||||||
|
|
||||||
|
tree - Element at the root of the hierarchy to merge.
|
||||||
|
apiNames - list of strings of API names."""
|
||||||
|
|
||||||
|
stack = deque()
|
||||||
|
stack.append(tree)
|
||||||
|
|
||||||
|
while len(stack) > 0:
|
||||||
|
parent = stack.pop()
|
||||||
|
|
||||||
|
for child in parent.findall('*'):
|
||||||
|
if child.tag == 'remove':
|
||||||
|
# Remove <remove> elements
|
||||||
|
parent.remove(child)
|
||||||
|
else:
|
||||||
|
stack.append(child)
|
||||||
|
|
||||||
|
supportedList = child.get('supported')
|
||||||
|
if supportedList:
|
||||||
|
supportedList = supportedList.split(',')
|
||||||
|
for apiName in [toApiName] + fromApiNames:
|
||||||
|
if apiName in supportedList:
|
||||||
|
child.set('supported', toApiName)
|
||||||
|
|
||||||
|
if child.get('api'):
|
||||||
|
definitionName = None
|
||||||
|
definitionVariants = []
|
||||||
|
|
||||||
|
# Keep only one definition with the same name if there are multiple definitions
|
||||||
|
if child.tag in ['type']:
|
||||||
|
if child.get('name') is not None:
|
||||||
|
definitionName = child.get('name')
|
||||||
|
definitionVariants = parent.findall(f"{child.tag}[@name='{definitionName}']")
|
||||||
|
else:
|
||||||
|
definitionName = child.find('name').text
|
||||||
|
definitionVariants = parent.findall(f"{child.tag}/name[.='{definitionName}']/..")
|
||||||
|
elif child.tag in ['member', 'param']:
|
||||||
|
definitionName = child.find('name').text
|
||||||
|
definitionVariants = parent.findall(f"{child.tag}/name[.='{definitionName}']/..")
|
||||||
|
elif child.tag in ['enum', 'feature']:
|
||||||
|
definitionName = child.get('name')
|
||||||
|
definitionVariants = parent.findall(f"{child.tag}[@name='{definitionName}']")
|
||||||
|
elif child.tag in ['require']:
|
||||||
|
definitionName = child.get('feature')
|
||||||
|
definitionVariants = parent.findall(f"{child.tag}[@feature='{definitionName}']")
|
||||||
|
elif child.tag in ['command']:
|
||||||
|
definitionName = child.find('proto/name').text
|
||||||
|
definitionVariants = parent.findall(f"{child.tag}/proto/name[.='{definitionName}']/../..")
|
||||||
|
|
||||||
|
if definitionName:
|
||||||
|
bestMatchApi = None
|
||||||
|
requires = None
|
||||||
|
for apiName in [toApiName] + fromApiNames:
|
||||||
|
for variant in definitionVariants:
|
||||||
|
# Keep any requires attributes from the target API
|
||||||
|
if variant.get('requires') and variant.get('api') == apiName:
|
||||||
|
requires = variant.get('requires')
|
||||||
|
# Find the best matching definition
|
||||||
|
if apiName in variant.get('api').split(',') and bestMatchApi is None:
|
||||||
|
bestMatchApi = variant.get('api')
|
||||||
|
|
||||||
|
if bestMatchApi:
|
||||||
|
for variant in definitionVariants:
|
||||||
|
if variant.get('api') != bestMatchApi:
|
||||||
|
# Only keep best matching definition
|
||||||
|
parent.remove(variant)
|
||||||
|
else:
|
||||||
|
# Add requires attribute from the target API if it is not overridden
|
||||||
|
if requires is not None and variant.get('requires') is None:
|
||||||
|
variant.set('requires', requires)
|
||||||
|
variant.set('api', toApiName)
|
||||||
|
|
||||||
|
|
||||||
def stripNonmatchingAPIs(tree, apiName, actuallyDelete = True):
|
def stripNonmatchingAPIs(tree, apiName, actuallyDelete = True):
|
||||||
"""Remove tree Elements with 'api' attributes matching apiName.
|
"""Remove tree Elements with 'api' attributes matching apiName.
|
||||||
|
|
||||||
@ -448,8 +524,10 @@ class Registry:
|
|||||||
raise RuntimeError("Tree not initialized!")
|
raise RuntimeError("Tree not initialized!")
|
||||||
self.reg = self.tree.getroot()
|
self.reg = self.tree.getroot()
|
||||||
|
|
||||||
# Preprocess the tree by removing all elements with non-matching
|
# Preprocess the tree in one of the following ways:
|
||||||
# 'api' attributes by breadth-first tree traversal.
|
# - either merge a set of APIs to another API based on their 'api' attributes
|
||||||
|
# - or remove all elements with non-matching 'api' attributes
|
||||||
|
# The preprocessing happens through a breath-first tree traversal.
|
||||||
# This is a blunt hammer, but eliminates the need to track and test
|
# This is a blunt hammer, but eliminates the need to track and test
|
||||||
# the apis deeper in processing to select the correct elements and
|
# the apis deeper in processing to select the correct elements and
|
||||||
# avoid duplicates.
|
# avoid duplicates.
|
||||||
@ -457,7 +535,10 @@ class Registry:
|
|||||||
# overlapping api attributes, or where one element has an api
|
# overlapping api attributes, or where one element has an api
|
||||||
# attribute and the other does not.
|
# attribute and the other does not.
|
||||||
|
|
||||||
stripNonmatchingAPIs(self.reg, self.genOpts.apiname, actuallyDelete = True)
|
if self.genOpts.mergeApiNames:
|
||||||
|
mergeAPIs(self.reg, self.genOpts.mergeApiNames.split(','), self.genOpts.apiname)
|
||||||
|
else:
|
||||||
|
stripNonmatchingAPIs(self.reg, self.genOpts.apiname, actuallyDelete = True)
|
||||||
|
|
||||||
# Create dictionary of registry types from toplevel <types> tags
|
# Create dictionary of registry types from toplevel <types> tags
|
||||||
# and add 'name' attribute to each <type> tag (where missing)
|
# and add 'name' attribute to each <type> tag (where missing)
|
||||||
@ -658,24 +739,6 @@ class Registry:
|
|||||||
enumInfo = EnumInfo(enum)
|
enumInfo = EnumInfo(enum)
|
||||||
self.addElementInfo(enum, enumInfo, 'enum', self.enumdict)
|
self.addElementInfo(enum, enumInfo, 'enum', self.enumdict)
|
||||||
|
|
||||||
# Construct a "validextensionstructs" list for parent structures
|
|
||||||
# based on "structextends" tags in child structures
|
|
||||||
disabled_types = []
|
|
||||||
for disabled_ext in self.reg.findall('extensions/extension[@supported="disabled"]'):
|
|
||||||
for type_elem in disabled_ext.findall("*/type"):
|
|
||||||
disabled_types.append(type_elem.get('name'))
|
|
||||||
for type_elem in self.reg.findall('types/type'):
|
|
||||||
if type_elem.get('name') not in disabled_types:
|
|
||||||
# The structure type this may be chained to.
|
|
||||||
struct_extends = type_elem.get('structextends')
|
|
||||||
if struct_extends is not None:
|
|
||||||
for parent in struct_extends.split(','):
|
|
||||||
# self.gen.logMsg('diag', type.get('name'), 'extends', parent)
|
|
||||||
self.validextensionstructs[parent].append(type_elem.get('name'))
|
|
||||||
# Sort the lists so they do not depend on the XML order
|
|
||||||
for parent in self.validextensionstructs:
|
|
||||||
self.validextensionstructs[parent].sort()
|
|
||||||
|
|
||||||
# Parse out all spirv tags in dictionaries
|
# Parse out all spirv tags in dictionaries
|
||||||
# Use addElementInfo to catch duplicates
|
# Use addElementInfo to catch duplicates
|
||||||
for spirv in self.reg.findall('spirvextensions/spirvextension'):
|
for spirv in self.reg.findall('spirvextensions/spirvextension'):
|
||||||
@ -945,6 +1008,8 @@ class Registry:
|
|||||||
if alias is None:
|
if alias is None:
|
||||||
name = elem.get('name')
|
name = elem.get('name')
|
||||||
typeinfo = self.lookupElementInfo(name, dict)
|
typeinfo = self.lookupElementInfo(name, dict)
|
||||||
|
if not typeinfo:
|
||||||
|
self.gen.logMsg('error', name, 'is not a known name')
|
||||||
alias = typeinfo.elem.get('alias')
|
alias = typeinfo.elem.get('alias')
|
||||||
|
|
||||||
return alias
|
return alias
|
||||||
@ -1000,10 +1065,8 @@ class Registry:
|
|||||||
# expression of extension names.
|
# expression of extension names.
|
||||||
# 'required_key' is used only as a dictionary key at
|
# 'required_key' is used only as a dictionary key at
|
||||||
# present, and passed through to the script generators, so
|
# present, and passed through to the script generators, so
|
||||||
# they must be prepared to parse that expression.
|
# they must be prepared to parse that boolean expression.
|
||||||
required_key = require.get('feature')
|
required_key = require.get('depends')
|
||||||
if required_key is None:
|
|
||||||
required_key = require.get('extension')
|
|
||||||
|
|
||||||
# Loop over types, enums, and commands in the tag
|
# Loop over types, enums, and commands in the tag
|
||||||
for typeElem in require.findall('type'):
|
for typeElem in require.findall('type'):
|
||||||
@ -1328,7 +1391,7 @@ class Registry:
|
|||||||
stripped = False
|
stripped = False
|
||||||
for api in attribstring.split(','):
|
for api in attribstring.split(','):
|
||||||
##print('Checking API {} referenced by {}'.format(api, key))
|
##print('Checking API {} referenced by {}'.format(api, key))
|
||||||
if supportedDictionary[api].required:
|
if api in supportedDictionary and supportedDictionary[api].required:
|
||||||
apis.append(api)
|
apis.append(api)
|
||||||
else:
|
else:
|
||||||
stripped = True
|
stripped = True
|
||||||
@ -1352,6 +1415,24 @@ class Registry:
|
|||||||
genProc = self.gen.genFormat
|
genProc = self.gen.genFormat
|
||||||
genProc(format, name, alias)
|
genProc(format, name, alias)
|
||||||
|
|
||||||
|
def tagValidExtensionStructs(self):
|
||||||
|
"""Construct a "validextensionstructs" list for parent structures
|
||||||
|
based on "structextends" tags in child structures.
|
||||||
|
Only do this for structures tagged as required."""
|
||||||
|
|
||||||
|
for typeinfo in self.typedict.values():
|
||||||
|
type_elem = typeinfo.elem
|
||||||
|
if typeinfo.required and type_elem.get('category') == 'struct':
|
||||||
|
struct_extends = type_elem.get('structextends')
|
||||||
|
if struct_extends is not None:
|
||||||
|
for parent in struct_extends.split(','):
|
||||||
|
# self.gen.logMsg('diag', type_elem.get('name'), 'extends', parent)
|
||||||
|
self.validextensionstructs[parent].append(type_elem.get('name'))
|
||||||
|
|
||||||
|
# Sort the lists so they do not depend on the XML order
|
||||||
|
for parent in self.validextensionstructs:
|
||||||
|
self.validextensionstructs[parent].sort()
|
||||||
|
|
||||||
def apiGen(self):
|
def apiGen(self):
|
||||||
"""Generate interface for specified versions using the current
|
"""Generate interface for specified versions using the current
|
||||||
generator and generator options"""
|
generator and generator options"""
|
||||||
@ -1523,6 +1604,9 @@ class Registry:
|
|||||||
self.stripUnsupportedAPIs(self.cmddict, 'successcodes', self.enumdict)
|
self.stripUnsupportedAPIs(self.cmddict, 'successcodes', self.enumdict)
|
||||||
self.stripUnsupportedAPIs(self.cmddict, 'errorcodes', self.enumdict)
|
self.stripUnsupportedAPIs(self.cmddict, 'errorcodes', self.enumdict)
|
||||||
|
|
||||||
|
# Construct lists of valid extension structures
|
||||||
|
self.tagValidExtensionStructs()
|
||||||
|
|
||||||
# @@May need to strip <spirvcapability> / <spirvextension> <enable>
|
# @@May need to strip <spirvcapability> / <spirvextension> <enable>
|
||||||
# tags of these forms:
|
# tags of these forms:
|
||||||
# <enable version="VK_API_VERSION_1_0"/>
|
# <enable version="VK_API_VERSION_1_0"/>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#!/usr/bin/python3 -i
|
#!/usr/bin/python3 -i
|
||||||
#
|
#
|
||||||
# Copyright 2013-2022 The Khronos Group Inc.
|
# Copyright 2013-2023 The Khronos Group Inc.
|
||||||
#
|
#
|
||||||
# SPDX-License-Identifier: Apache-2.0
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
@ -34,6 +34,11 @@ TYPES_KNOWN_ALWAYS_VALID = set(('char',
|
|||||||
# Split an extension name into vendor ID and name portions
|
# Split an extension name into vendor ID and name portions
|
||||||
EXT_NAME_DECOMPOSE_RE = re.compile(r'[A-Z]+_(?P<vendor>[A-Z]+)_(?P<name>[\w_]+)')
|
EXT_NAME_DECOMPOSE_RE = re.compile(r'[A-Z]+_(?P<vendor>[A-Z]+)_(?P<name>[\w_]+)')
|
||||||
|
|
||||||
|
# Match an API version name.
|
||||||
|
# This could be refined further for specific APIs.
|
||||||
|
API_VERSION_NAME_RE = re.compile(r'[A-Z]+_VERSION_[0-9]')
|
||||||
|
|
||||||
|
|
||||||
class ProseListFormats(Enum):
|
class ProseListFormats(Enum):
|
||||||
"""A connective, possibly with a quantifier."""
|
"""A connective, possibly with a quantifier."""
|
||||||
AND = 0
|
AND = 0
|
||||||
@ -443,3 +448,7 @@ class ConventionsBase(abc.ABC):
|
|||||||
reference pages."""
|
reference pages."""
|
||||||
return ''
|
return ''
|
||||||
|
|
||||||
|
def is_api_version_name(self, name):
|
||||||
|
"""Return True if name is an API version name."""
|
||||||
|
|
||||||
|
return API_VERSION_NAME_RE.match(name) is not None
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
"""Utility functions not closely tied to other spec_tools types."""
|
"""Utility functions not closely tied to other spec_tools types."""
|
||||||
# Copyright (c) 2018-2019 Collabora, Ltd.
|
# Copyright (c) 2018-2019 Collabora, Ltd.
|
||||||
# Copyright 2013-2022 The Khronos Group Inc.
|
# Copyright 2013-2023 The Khronos Group Inc.
|
||||||
#
|
#
|
||||||
# SPDX-License-Identifier: Apache-2.0
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
42
registry/stripAPI.py
Normal file
42
registry/stripAPI.py
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
#!/usr/bin/python3
|
||||||
|
#
|
||||||
|
# Copyright 2023 The Khronos Group Inc.
|
||||||
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
import argparse
|
||||||
|
import xml.etree.ElementTree as etree
|
||||||
|
from reg import stripNonmatchingAPIs
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
parser = argparse.ArgumentParser(prog='stripAPI',
|
||||||
|
formatter_class=argparse.RawDescriptionHelpFormatter,
|
||||||
|
description='''\
|
||||||
|
Filters out elements with non-matching explicit 'api' attributes from API XML.
|
||||||
|
To remove Vulkan SC-only elements from the combined API XML:
|
||||||
|
python3 scripts/stripAPI.py -input xml/vk.xml -output vulkan-only.xml -keepAPI vulkan
|
||||||
|
To remove Vulkan-only elements:
|
||||||
|
python3 scripts/stripAPI.py -input xml/vk.xml -output vulkansc-only.xml -keepAPI vulkansc
|
||||||
|
If you are parsing the XML yourself but using the xml.etree package, the
|
||||||
|
equivalent runtime code is:
|
||||||
|
import reg
|
||||||
|
reg.stripNonmatchingAPIs(tree.getroot(), keepAPI, actuallyDelete=True)
|
||||||
|
where 'tree' is an ElementTree created from the XML file using
|
||||||
|
etree.parse(filename)''')
|
||||||
|
|
||||||
|
parser.add_argument('-input', action='store',
|
||||||
|
required=True,
|
||||||
|
help='Specify input registry XML')
|
||||||
|
parser.add_argument('-output', action='store',
|
||||||
|
required=True,
|
||||||
|
help='Specify output registry XML')
|
||||||
|
parser.add_argument('-keepAPI', action='store',
|
||||||
|
default=None,
|
||||||
|
help='Specify API name whose \'api\' tags are kept')
|
||||||
|
|
||||||
|
args = parser.parse_args()
|
||||||
|
|
||||||
|
tree = etree.parse(args.input)
|
||||||
|
if args.keepAPI is not None:
|
||||||
|
stripNonmatchingAPIs(tree.getroot(), args.keepAPI, actuallyDelete = True)
|
||||||
|
tree.write(args.output)
|
||||||
|
|
30510
registry/validusage.json
30510
registry/validusage.json
File diff suppressed because one or more lines are too long
@ -1,15 +1,14 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<registry>
|
<registry>
|
||||||
<comment>
|
<comment>
|
||||||
Copyright 2021-2022 The Khronos Group Inc.
|
Copyright 2021-2023 The Khronos Group Inc.
|
||||||
SPDX-License-Identifier: Apache-2.0 OR MIT
|
SPDX-License-Identifier: Apache-2.0 OR MIT
|
||||||
</comment>
|
</comment>
|
||||||
|
|
||||||
<comment>
|
<comment>
|
||||||
This file, video.xml, is NOT a normative part of the Vulkan Specification.
|
This file, video.xml, provides the machine readable definition of data
|
||||||
It includes a machine-readable definition of data structures and
|
structures and enumerations that are related to the externally-provided
|
||||||
enumerations that are associated with externally-provided video standards,
|
video compression standards.
|
||||||
and are non-normatively referred to by Khronos extensions to Vulkan.
|
|
||||||
|
|
||||||
The current public version of video.xml is maintained in the default branch
|
The current public version of video.xml is maintained in the default branch
|
||||||
(currently named main) of the Khronos Vulkan GitHub project.
|
(currently named main) of the Khronos Vulkan GitHub project.
|
||||||
@ -29,20 +28,20 @@ The current public version of video.xml is maintained in the default branch
|
|||||||
((((uint32_t)(major)) << 22) | (((uint32_t)(minor)) << 12) | ((uint32_t)(patch)))</type>
|
((((uint32_t)(major)) << 22) | (((uint32_t)(minor)) << 12) | ((uint32_t)(patch)))</type>
|
||||||
|
|
||||||
<!-- vulkan_video_codec_h264std_decode.h macros -->
|
<!-- vulkan_video_codec_h264std_decode.h macros -->
|
||||||
<type category="define" requires="VK_MAKE_VIDEO_STD_VERSION">// Vulkan 0.9 provisional Vulkan video H.264 decode std specification version number
|
<type category="define" requires="VK_MAKE_VIDEO_STD_VERSION">
|
||||||
#define <name>VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_API_VERSION_0_9_8</name> <type>VK_MAKE_VIDEO_STD_VERSION</type>(0, 9, 8) // Patch version should always be set to 0</type>
|
#define <name>VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_API_VERSION_1_0_0</name> <type>VK_MAKE_VIDEO_STD_VERSION</type>(1, 0, 0)</type>
|
||||||
|
|
||||||
<!-- vulkan_video_codec_h264std_encode.h macros -->
|
<!-- vulkan_video_codec_h264std_encode.h macros -->
|
||||||
<type category="define" requires="VK_MAKE_VIDEO_STD_VERSION">// Vulkan 0.9 provisional Vulkan video H.264 encode std specification version number
|
<type category="define" requires="VK_MAKE_VIDEO_STD_VERSION">// Vulkan 0.9 provisional Vulkan video H.264 encode std specification version number
|
||||||
#define <name>VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_API_VERSION_0_9_8</name> <type>VK_MAKE_VIDEO_STD_VERSION</type>(0, 9, 8) // Patch version should always be set to 0</type>
|
#define <name>VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_API_VERSION_0_9_9</name> <type>VK_MAKE_VIDEO_STD_VERSION</type>(0, 9, 9)</type>
|
||||||
|
|
||||||
<!-- vulkan_video_codec_h265std_decode.h macros -->
|
<!-- vulkan_video_codec_h265std_decode.h macros -->
|
||||||
<type category="define" requires="VK_MAKE_VIDEO_STD_VERSION">// Vulkan 0.9 provisional Vulkan video H.265 decode std specification version number
|
<type category="define" requires="VK_MAKE_VIDEO_STD_VERSION">
|
||||||
#define <name>VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_API_VERSION_0_9_9</name> <type>VK_MAKE_VIDEO_STD_VERSION</type>(0, 9, 9) // Patch version should always be set to 0</type>
|
#define <name>VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_API_VERSION_1_0_0</name> <type>VK_MAKE_VIDEO_STD_VERSION</type>(1, 0, 0)</type>
|
||||||
|
|
||||||
<!-- vulkan_video_codec_h265std_encode.h macros -->
|
<!-- vulkan_video_codec_h265std_encode.h macros -->
|
||||||
<type category="define" requires="VK_MAKE_VIDEO_STD_VERSION">// Vulkan 0.9 provisional Vulkan video H.265 encode std specification version number
|
<type category="define" requires="VK_MAKE_VIDEO_STD_VERSION">// Vulkan 0.9 provisional Vulkan video H.265 encode std specification version number
|
||||||
#define <name>VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_API_VERSION_0_9_9</name> <type>VK_MAKE_VIDEO_STD_VERSION</type>(0, 9, 9) // Patch version should always be set to 0</type>
|
#define <name>VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_API_VERSION_0_9_10</name> <type>VK_MAKE_VIDEO_STD_VERSION</type>(0, 9, 10)</type>
|
||||||
|
|
||||||
<!-- vulkan_video_codec_h264std.h enumerated types -->
|
<!-- vulkan_video_codec_h264std.h enumerated types -->
|
||||||
<type name="StdVideoH264ChromaFormatIdc" category="enum"/>
|
<type name="StdVideoH264ChromaFormatIdc" category="enum"/>
|
||||||
@ -280,9 +279,9 @@ The current public version of video.xml is maintained in the default branch
|
|||||||
<type category="struct" name="StdVideoEncodeH264ReferenceInfoFlags">
|
<type category="struct" name="StdVideoEncodeH264ReferenceInfoFlags">
|
||||||
<member><type>uint32_t</type> <name>used_for_long_term_reference</name> : 1<comment>: A picture that is marked as "used for long-term reference", derived binary value from clause 8.2.5.1 Sequence of operations for decoded reference picture marking process</comment></member>
|
<member><type>uint32_t</type> <name>used_for_long_term_reference</name> : 1<comment>: A picture that is marked as "used for long-term reference", derived binary value from clause 8.2.5.1 Sequence of operations for decoded reference picture marking process</comment></member>
|
||||||
</type>
|
</type>
|
||||||
<type category="struct" name="StdVideoEncodeH264RefMgmtFlags">
|
<type category="struct" name="StdVideoEncodeH264ReferenceListsInfoFlags">
|
||||||
<member><type>uint32_t</type> <name>ref_pic_list_modification_l0_flag</name> : 1</member>
|
<member><type>uint32_t</type> <name>ref_pic_list_modification_flag_l0</name> : 1</member>
|
||||||
<member><type>uint32_t</type> <name>ref_pic_list_modification_l1_flag</name> : 1</member>
|
<member><type>uint32_t</type> <name>ref_pic_list_modification_flag_l1</name> : 1</member>
|
||||||
</type>
|
</type>
|
||||||
<type category="struct" name="StdVideoEncodeH264RefListModEntry">
|
<type category="struct" name="StdVideoEncodeH264RefListModEntry">
|
||||||
<member><type>StdVideoH264ModificationOfPicNumsIdc</type> <name>modification_of_pic_nums_idc</name></member>
|
<member><type>StdVideoH264ModificationOfPicNumsIdc</type> <name>modification_of_pic_nums_idc</name></member>
|
||||||
@ -296,25 +295,32 @@ The current public version of video.xml is maintained in the default branch
|
|||||||
<member><type>uint16_t</type> <name>long_term_frame_idx</name></member>
|
<member><type>uint16_t</type> <name>long_term_frame_idx</name></member>
|
||||||
<member><type>uint16_t</type> <name>max_long_term_frame_idx_plus1</name></member>
|
<member><type>uint16_t</type> <name>max_long_term_frame_idx_plus1</name></member>
|
||||||
</type>
|
</type>
|
||||||
<type category="struct" name="StdVideoEncodeH264RefMemMgmtCtrlOperations">
|
<type category="struct" name="StdVideoEncodeH264ReferenceListsInfo">
|
||||||
<member><type>StdVideoEncodeH264RefMgmtFlags</type> <name>flags</name></member>
|
<member><type>StdVideoEncodeH264ReferenceListsInfoFlags</type> <name>flags</name></member>
|
||||||
|
<member><type>uint8_t</type> <name>refPicList0EntryCount</name><comment>num_ref_idx_l0_active_minus1 plus one</comment></member>
|
||||||
|
<member><type>uint8_t</type> <name>refPicList1EntryCount</name><comment>num_ref_idx_l1_active_minus1 plus one</comment></member>
|
||||||
<member><type>uint8_t</type> <name>refList0ModOpCount</name></member>
|
<member><type>uint8_t</type> <name>refList0ModOpCount</name></member>
|
||||||
<member>const <type>StdVideoEncodeH264RefListModEntry</type>* <name>pRefList0ModOperations</name></member>
|
|
||||||
<member><type>uint8_t</type> <name>refList1ModOpCount</name></member>
|
<member><type>uint8_t</type> <name>refList1ModOpCount</name></member>
|
||||||
<member>const <type>StdVideoEncodeH264RefListModEntry</type>* <name>pRefList1ModOperations</name></member>
|
|
||||||
<member><type>uint8_t</type> <name>refPicMarkingOpCount</name></member>
|
<member><type>uint8_t</type> <name>refPicMarkingOpCount</name></member>
|
||||||
<member>const <type>StdVideoEncodeH264RefPicMarkingEntry</type>* <name>pRefPicMarkingOperations</name></member>
|
<member><type>uint8_t</type> <name>reserved1</name>[7]<comment>Reserved for future use and must be initialized with 0.</comment></member>
|
||||||
|
<member>const <type>uint8_t</type>* <name>pRefPicList0Entries</name><comment>Must be a valid pointer to an array with size refPicList0EntryCount and contains the slotIndex values corresponding to the RefPicList0 as used in VkVideoReferenceSlotInfoKHR structures, 0xff for invalid slotIndex.</comment></member>
|
||||||
|
<member>const <type>uint8_t</type>* <name>pRefPicList1Entries</name><comment>Must be a valid pointer to an array with size refPicList1EntryCount and contains the slotIndex values corresponding to the RefPicList1 as used in VkVideoReferenceSlotInfoKHR structures, 0xff for invalid slotIndex.</comment></member>
|
||||||
|
<member>const <type>StdVideoEncodeH264RefListModEntry</type>* <name>pRefList0ModOperations</name><comment>Must be a valid pointer to an array with size refList0ModOpCount if ref_pic_list_modification_flag_l0 is set and contains the RefList0 modification parameters as defined in section 7.4.3.1</comment></member>
|
||||||
|
<member>const <type>StdVideoEncodeH264RefListModEntry</type>* <name>pRefList1ModOperations</name><comment>Must be a valid pointer to an array with size refList1ModOpCount if ref_pic_list_modification_flag_l1 is set and contains the RefList1 modification parameters as defined in section 7.4.3.1</comment></member>
|
||||||
|
<member>const <type>StdVideoEncodeH264RefPicMarkingEntry</type>* <name>pRefPicMarkingOperations</name><comment>Must be a valid pointer to an array with size refPicMarkingOpCount and contains the reference picture markings as defined in section 7.4.3.3</comment></member>
|
||||||
</type>
|
</type>
|
||||||
<type category="struct" name="StdVideoEncodeH264PictureInfo">
|
<type category="struct" name="StdVideoEncodeH264PictureInfo">
|
||||||
<member><type>StdVideoEncodeH264PictureInfoFlags</type> <name>flags</name></member>
|
<member><type>StdVideoEncodeH264PictureInfoFlags</type> <name>flags</name></member>
|
||||||
<member><type>uint8_t</type> <name>seq_parameter_set_id</name><comment>Selecting SPS id from the Sequence Parameters Set</comment></member>
|
<member><type>uint8_t</type> <name>seq_parameter_set_id</name><comment>Selecting SPS id from the Sequence Parameters Set</comment></member>
|
||||||
<member><type>uint8_t</type> <name>pic_parameter_set_id</name><comment>Selecting PPS from the Picture Parameters for all StdVideoEncodeH264SliceHeader(s)</comment></member>
|
<member><type>uint8_t</type> <name>pic_parameter_set_id</name><comment>Selecting PPS from the Picture Parameters for all StdVideoEncodeH264SliceHeader(s)</comment></member>
|
||||||
|
<member><type>uint16_t</type> <name>reserved1</name><comment>Reserved for future use and must be initialized with 0.</comment></member>
|
||||||
<member><type>StdVideoH264PictureType</type> <name>pictureType</name></member>
|
<member><type>StdVideoH264PictureType</type> <name>pictureType</name></member>
|
||||||
<member><type>uint32_t</type> <name>frame_num</name></member>
|
<member><type>uint32_t</type> <name>frame_num</name></member>
|
||||||
<member><type>int32_t</type> <name>PicOrderCnt</name></member>
|
<member><type>int32_t</type> <name>PicOrderCnt</name></member>
|
||||||
</type>
|
</type>
|
||||||
<type category="struct" name="StdVideoEncodeH264ReferenceInfo">
|
<type category="struct" name="StdVideoEncodeH264ReferenceInfo">
|
||||||
<member><type>StdVideoEncodeH264ReferenceInfoFlags</type> <name>flags</name></member>
|
<member><type>StdVideoEncodeH264ReferenceInfoFlags</type> <name>flags</name></member>
|
||||||
|
<member><type>StdVideoH264PictureType</type> <name>pictureType</name></member>
|
||||||
<member><type>uint32_t</type> <name>FrameNum</name></member>
|
<member><type>uint32_t</type> <name>FrameNum</name></member>
|
||||||
<member><type>int32_t</type> <name>PicOrderCnt</name></member>
|
<member><type>int32_t</type> <name>PicOrderCnt</name></member>
|
||||||
<member><type>uint16_t</type> <name>long_term_pic_num</name></member>
|
<member><type>uint16_t</type> <name>long_term_pic_num</name></member>
|
||||||
@ -331,6 +337,8 @@ The current public version of video.xml is maintained in the default branch
|
|||||||
<member><type>StdVideoH264DisableDeblockingFilterIdc</type> <name>disable_deblocking_filter_idc</name></member>
|
<member><type>StdVideoH264DisableDeblockingFilterIdc</type> <name>disable_deblocking_filter_idc</name></member>
|
||||||
<member><type>int8_t</type> <name>slice_alpha_c0_offset_div2</name></member>
|
<member><type>int8_t</type> <name>slice_alpha_c0_offset_div2</name></member>
|
||||||
<member><type>int8_t</type> <name>slice_beta_offset_div2</name></member>
|
<member><type>int8_t</type> <name>slice_beta_offset_div2</name></member>
|
||||||
|
<member><type>uint16_t</type> <name>reserved1</name><comment>Reserved for future use and must be initialized with 0.</comment></member>
|
||||||
|
<member><type>uint32_t</type> <name>reserved2</name><comment>Reserved for future use and must be initialized with 0.</comment></member>
|
||||||
<member>const <type>StdVideoEncodeH264WeightTable</type>* <name>pWeightTable</name><comment></comment></member>
|
<member>const <type>StdVideoEncodeH264WeightTable</type>* <name>pWeightTable</name><comment></comment></member>
|
||||||
</type>
|
</type>
|
||||||
|
|
||||||
@ -433,8 +441,8 @@ The current public version of video.xml is maintained in the default branch
|
|||||||
<member><type>uint16_t</type> <name>used_by_curr_pic_flag</name><comment>each bit represents a used_by_curr_pic_flag[j] syntax</comment></member>
|
<member><type>uint16_t</type> <name>used_by_curr_pic_flag</name><comment>each bit represents a used_by_curr_pic_flag[j] syntax</comment></member>
|
||||||
<member><type>uint16_t</type> <name>used_by_curr_pic_s0_flag</name><comment>each bit represents a used_by_curr_pic_s0_flag[i] syntax</comment></member>
|
<member><type>uint16_t</type> <name>used_by_curr_pic_s0_flag</name><comment>each bit represents a used_by_curr_pic_s0_flag[i] syntax</comment></member>
|
||||||
<member><type>uint16_t</type> <name>used_by_curr_pic_s1_flag</name><comment>each bit represents a used_by_curr_pic_s1_flag[i] syntax</comment></member>
|
<member><type>uint16_t</type> <name>used_by_curr_pic_s1_flag</name><comment>each bit represents a used_by_curr_pic_s1_flag[i] syntax</comment></member>
|
||||||
<member><type>uint16_t</type> <name>reserved1</name><comment>Reserved for future use and must be initialized with 0.</comment></member>
|
<member><type>uint16_t</type> <name>reserved1</name><comment>Reserved for future use and must be initialized with 0.</comment></member>
|
||||||
<member><type>uint8_t</type> <name>reserved2</name><comment>Reserved for future use and must be initialized with 0.</comment></member>
|
<member><type>uint8_t</type> <name>reserved2</name><comment>Reserved for future use and must be initialized with 0.</comment></member>
|
||||||
<member><type>uint8_t</type> <name>reserved3</name><comment>Reserved for future use and must be initialized with 0.</comment></member>
|
<member><type>uint8_t</type> <name>reserved3</name><comment>Reserved for future use and must be initialized with 0.</comment></member>
|
||||||
<member><type>uint8_t</type> <name>num_negative_pics</name></member>
|
<member><type>uint8_t</type> <name>num_negative_pics</name></member>
|
||||||
<member><type>uint8_t</type> <name>num_positive_pics</name></member>
|
<member><type>uint8_t</type> <name>num_positive_pics</name></member>
|
||||||
@ -768,16 +776,19 @@ The current public version of video.xml is maintained in the default branch
|
|||||||
<member>const <type>StdVideoEncodeH265SliceSegmentLongTermRefPics</type>*<name>pLongTermRefPics</name><comment>Must be a valid pointer if StdVideoH265SpsFlags:long_term_ref_pics_present_flag is set</comment></member>
|
<member>const <type>StdVideoEncodeH265SliceSegmentLongTermRefPics</type>*<name>pLongTermRefPics</name><comment>Must be a valid pointer if StdVideoH265SpsFlags:long_term_ref_pics_present_flag is set</comment></member>
|
||||||
<member>const <type>StdVideoEncodeH265WeightTable</type>* <name>pWeightTable</name><comment></comment></member>
|
<member>const <type>StdVideoEncodeH265WeightTable</type>* <name>pWeightTable</name><comment></comment></member>
|
||||||
</type>
|
</type>
|
||||||
<type category="struct" name="StdVideoEncodeH265ReferenceModificationFlags">
|
<type category="struct" name="StdVideoEncodeH265ReferenceListsInfoFlags">
|
||||||
<member><type>uint32_t</type> <name>ref_pic_list_modification_flag_l0</name> : 1</member>
|
<member><type>uint32_t</type> <name>ref_pic_list_modification_flag_l0</name> : 1</member>
|
||||||
<member><type>uint32_t</type> <name>ref_pic_list_modification_flag_l1</name> : 1</member>
|
<member><type>uint32_t</type> <name>ref_pic_list_modification_flag_l1</name> : 1</member>
|
||||||
</type>
|
</type>
|
||||||
<type category="struct" name="StdVideoEncodeH265ReferenceModifications">
|
<type category="struct" name="StdVideoEncodeH265ReferenceListsInfo">
|
||||||
<member><type>StdVideoEncodeH265ReferenceModificationFlags</type> <name>flags</name></member>
|
<member><type>StdVideoEncodeH265ReferenceListsInfoFlags</type> <name>flags</name></member>
|
||||||
<member><type>uint8_t</type> <name>referenceList0ModificationsCount</name><comment>num_ref_idx_l0_active_minus1</comment></member>
|
<member><type>uint8_t</type> <name>num_ref_idx_l0_active_minus1</name></member>
|
||||||
<member>const <type>uint8_t</type>* <name>pReferenceList0Modifications</name><comment>list_entry_l0</comment></member>
|
<member><type>uint8_t</type> <name>num_ref_idx_l1_active_minus1</name></member>
|
||||||
<member><type>uint8_t</type> <name>referenceList1ModificationsCount</name><comment>num_ref_idx_l1_active_minus1</comment></member>
|
<member><type>uint16_t</type> <name>reserved1</name><comment>Reserved for future use and must be initialized with 0.</comment></member>
|
||||||
<member>const <type>uint8_t</type>* <name>pReferenceList1Modifications</name><comment>list_entry_l1</comment></member>
|
<member>const <type>uint8_t</type>* <name>pRefPicList0Entries</name><comment>Must be a valid pointer to an array with size num_ref_idx_l0_active_minus1 plus 1 and contains the slotIndex values corresponding to the RefPicList0 as used in VkVideoReferenceSlotInfoKHR structures, 0xff for invalid slotIndex.</comment></member>
|
||||||
|
<member>const <type>uint8_t</type>* <name>pRefPicList1Entries</name><comment>Must be a valid pointer to an array with size num_ref_idx_l1_active_minus1 plus 1 and contains the slotIndex values corresponding to the RefPicList1 as used in VkVideoReferenceSlotInfoKHR structures, 0xff for invalid slotIndex.</comment></member>
|
||||||
|
<member>const <type>uint8_t</type>* <name>pRefList0Modifications</name><comment>Must be a valid pointer to an array with size num_ref_idx_l0_active_minus1 plus 1 if ref_pic_list_modification_flag_l0 is set and contains the elements of list_entry_l0.</comment></member>
|
||||||
|
<member>const <type>uint8_t</type>* <name>pRefList1Modifications</name><comment>Must be a valid pointer to an array with size num_ref_idx_l1_active_minus1 plus 1 if ref_pic_list_modification_flag_l1 is set and contains the elements of list_entry_l1.</comment></member>
|
||||||
</type>
|
</type>
|
||||||
<type category="struct" name="StdVideoEncodeH265PictureInfoFlags">
|
<type category="struct" name="StdVideoEncodeH265PictureInfoFlags">
|
||||||
<member><type>uint32_t</type> <name>is_reference_flag</name> : 1</member>
|
<member><type>uint32_t</type> <name>is_reference_flag</name> : 1</member>
|
||||||
@ -792,8 +803,8 @@ The current public version of video.xml is maintained in the default branch
|
|||||||
<member><type>uint8_t</type> <name>sps_video_parameter_set_id</name><comment>Selecting VPS id from the Video Parameters Set</comment></member>
|
<member><type>uint8_t</type> <name>sps_video_parameter_set_id</name><comment>Selecting VPS id from the Video Parameters Set</comment></member>
|
||||||
<member><type>uint8_t</type> <name>pps_seq_parameter_set_id</name><comment>Selecting SPS id from the Sequence Parameters Set</comment></member>
|
<member><type>uint8_t</type> <name>pps_seq_parameter_set_id</name><comment>Selecting SPS id from the Sequence Parameters Set</comment></member>
|
||||||
<member><type>uint8_t</type> <name>pps_pic_parameter_set_id</name><comment>Selecting PPS id from the Picture Parameters Set</comment></member>
|
<member><type>uint8_t</type> <name>pps_pic_parameter_set_id</name><comment>Selecting PPS id from the Picture Parameters Set</comment></member>
|
||||||
<member><type>int32_t</type> <name>PicOrderCntVal</name></member>
|
|
||||||
<member><type>uint8_t</type> <name>TemporalId</name></member>
|
<member><type>uint8_t</type> <name>TemporalId</name></member>
|
||||||
|
<member><type>int32_t</type> <name>PicOrderCntVal</name></member>
|
||||||
</type>
|
</type>
|
||||||
<type category="struct" name="StdVideoEncodeH265ReferenceInfoFlags">
|
<type category="struct" name="StdVideoEncodeH265ReferenceInfoFlags">
|
||||||
<member><type>uint32_t</type> <name>used_for_long_term_reference</name> : 1<comment>A picture that is marked as "used for long-term reference", derived binary value from clause 8.3.2 Decoding process for reference picture set</comment></member>
|
<member><type>uint32_t</type> <name>used_for_long_term_reference</name> : 1<comment>A picture that is marked as "used for long-term reference", derived binary value from clause 8.3.2 Decoding process for reference picture set</comment></member>
|
||||||
@ -802,6 +813,7 @@ The current public version of video.xml is maintained in the default branch
|
|||||||
|
|
||||||
<type category="struct" name="StdVideoEncodeH265ReferenceInfo">
|
<type category="struct" name="StdVideoEncodeH265ReferenceInfo">
|
||||||
<member><type>StdVideoEncodeH265ReferenceInfoFlags</type> <name>flags</name></member>
|
<member><type>StdVideoEncodeH265ReferenceInfoFlags</type> <name>flags</name></member>
|
||||||
|
<member><type>StdVideoH265PictureType</type> <name>PictureType</name></member>
|
||||||
<member><type>int32_t</type> <name>PicOrderCntVal</name></member>
|
<member><type>int32_t</type> <name>PicOrderCntVal</name></member>
|
||||||
<member><type>uint8_t</type> <name>TemporalId</name></member>
|
<member><type>uint8_t</type> <name>TemporalId</name></member>
|
||||||
</type>
|
</type>
|
||||||
@ -1058,8 +1070,8 @@ The current public version of video.xml is maintained in the default branch
|
|||||||
<require>
|
<require>
|
||||||
<type name="vk_video/vulkan_video_codec_h264std.h"/>
|
<type name="vk_video/vulkan_video_codec_h264std.h"/>
|
||||||
|
|
||||||
<type name="VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_API_VERSION_0_9_8"/>
|
<type name="VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_API_VERSION_1_0_0"/>
|
||||||
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_SPEC_VERSION" value="VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_API_VERSION_0_9_8"/>
|
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_SPEC_VERSION" value="VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_API_VERSION_1_0_0"/>
|
||||||
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_EXTENSION_NAME" value=""VK_STD_vulkan_video_codec_h264_decode""/>
|
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H264_DECODE_EXTENSION_NAME" value=""VK_STD_vulkan_video_codec_h264_decode""/>
|
||||||
|
|
||||||
<enum name="STD_VIDEO_DECODE_H264_FIELD_ORDER_COUNT_LIST_SIZE" value="2"/>
|
<enum name="STD_VIDEO_DECODE_H264_FIELD_ORDER_COUNT_LIST_SIZE" value="2"/>
|
||||||
@ -1075,8 +1087,8 @@ The current public version of video.xml is maintained in the default branch
|
|||||||
<require>
|
<require>
|
||||||
<type name="vk_video/vulkan_video_codec_h264std.h"/>
|
<type name="vk_video/vulkan_video_codec_h264std.h"/>
|
||||||
|
|
||||||
<type name="VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_API_VERSION_0_9_8"/>
|
<type name="VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_API_VERSION_0_9_9"/>
|
||||||
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_SPEC_VERSION" value="VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_API_VERSION_0_9_8"/>
|
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_SPEC_VERSION" value="VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_API_VERSION_0_9_9"/>
|
||||||
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_EXTENSION_NAME" value=""VK_STD_vulkan_video_codec_h264_encode""/>
|
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H264_ENCODE_EXTENSION_NAME" value=""VK_STD_vulkan_video_codec_h264_encode""/>
|
||||||
|
|
||||||
<type name="StdVideoEncodeH264WeightTableFlags"/>
|
<type name="StdVideoEncodeH264WeightTableFlags"/>
|
||||||
@ -1084,10 +1096,10 @@ The current public version of video.xml is maintained in the default branch
|
|||||||
<type name="StdVideoEncodeH264SliceHeaderFlags"/>
|
<type name="StdVideoEncodeH264SliceHeaderFlags"/>
|
||||||
<type name="StdVideoEncodeH264PictureInfoFlags"/>
|
<type name="StdVideoEncodeH264PictureInfoFlags"/>
|
||||||
<type name="StdVideoEncodeH264ReferenceInfoFlags"/>
|
<type name="StdVideoEncodeH264ReferenceInfoFlags"/>
|
||||||
<type name="StdVideoEncodeH264RefMgmtFlags"/>
|
<type name="StdVideoEncodeH264ReferenceListsInfoFlags"/>
|
||||||
|
<type name="StdVideoEncodeH264ReferenceListsInfo"/>
|
||||||
<type name="StdVideoEncodeH264RefListModEntry"/>
|
<type name="StdVideoEncodeH264RefListModEntry"/>
|
||||||
<type name="StdVideoEncodeH264RefPicMarkingEntry"/>
|
<type name="StdVideoEncodeH264RefPicMarkingEntry"/>
|
||||||
<type name="StdVideoEncodeH264RefMemMgmtCtrlOperations"/>
|
|
||||||
<type name="StdVideoEncodeH264PictureInfo"/>
|
<type name="StdVideoEncodeH264PictureInfo"/>
|
||||||
<type name="StdVideoEncodeH264ReferenceInfo"/>
|
<type name="StdVideoEncodeH264ReferenceInfo"/>
|
||||||
<type name="StdVideoEncodeH264SliceHeader"/>
|
<type name="StdVideoEncodeH264SliceHeader"/>
|
||||||
@ -1146,8 +1158,8 @@ The current public version of video.xml is maintained in the default branch
|
|||||||
<require>
|
<require>
|
||||||
<type name="vk_video/vulkan_video_codec_h265std.h"/>
|
<type name="vk_video/vulkan_video_codec_h265std.h"/>
|
||||||
|
|
||||||
<type name="VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_API_VERSION_0_9_9"/>
|
<type name="VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_API_VERSION_1_0_0"/>
|
||||||
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_SPEC_VERSION" value="VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_API_VERSION_0_9_9"/>
|
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_SPEC_VERSION" value="VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_API_VERSION_1_0_0"/>
|
||||||
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_EXTENSION_NAME" value=""VK_STD_vulkan_video_codec_h265_decode""/>
|
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H265_DECODE_EXTENSION_NAME" value=""VK_STD_vulkan_video_codec_h265_decode""/>
|
||||||
|
|
||||||
<enum name="STD_VIDEO_DECODE_H265_REF_PIC_SET_LIST_SIZE" value="8"/>
|
<enum name="STD_VIDEO_DECODE_H265_REF_PIC_SET_LIST_SIZE" value="8"/>
|
||||||
@ -1162,16 +1174,16 @@ The current public version of video.xml is maintained in the default branch
|
|||||||
<require>
|
<require>
|
||||||
<type name="vk_video/vulkan_video_codec_h265std.h"/>
|
<type name="vk_video/vulkan_video_codec_h265std.h"/>
|
||||||
|
|
||||||
<type name="VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_API_VERSION_0_9_9"/>
|
<type name="VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_API_VERSION_0_9_10"/>
|
||||||
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_SPEC_VERSION" value="VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_API_VERSION_0_9_9"/>
|
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_SPEC_VERSION" value="VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_API_VERSION_0_9_10"/>
|
||||||
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_EXTENSION_NAME" value=""VK_STD_vulkan_video_codec_h265_encode""/>
|
<enum name="VK_STD_VULKAN_VIDEO_CODEC_H265_ENCODE_EXTENSION_NAME" value=""VK_STD_vulkan_video_codec_h265_encode""/>
|
||||||
|
|
||||||
<type name="StdVideoEncodeH265WeightTableFlags"/>
|
<type name="StdVideoEncodeH265WeightTableFlags"/>
|
||||||
<type name="StdVideoEncodeH265WeightTable"/>
|
<type name="StdVideoEncodeH265WeightTable"/>
|
||||||
<type name="StdVideoEncodeH265SliceSegmentHeaderFlags"/>
|
<type name="StdVideoEncodeH265SliceSegmentHeaderFlags"/>
|
||||||
<type name="StdVideoEncodeH265SliceSegmentHeader"/>
|
<type name="StdVideoEncodeH265SliceSegmentHeader"/>
|
||||||
<type name="StdVideoEncodeH265ReferenceModificationFlags"/>
|
<type name="StdVideoEncodeH265ReferenceListsInfoFlags"/>
|
||||||
<type name="StdVideoEncodeH265ReferenceModifications"/>
|
<type name="StdVideoEncodeH265ReferenceListsInfo"/>
|
||||||
<type name="StdVideoEncodeH265PictureInfoFlags"/>
|
<type name="StdVideoEncodeH265PictureInfoFlags"/>
|
||||||
<type name="StdVideoEncodeH265PictureInfo"/>
|
<type name="StdVideoEncodeH265PictureInfo"/>
|
||||||
<type name="StdVideoEncodeH265ReferenceInfoFlags"/>
|
<type name="StdVideoEncodeH265ReferenceInfoFlags"/>
|
||||||
|
3344
registry/vk.xml
3344
registry/vk.xml
File diff suppressed because it is too large
Load Diff
@ -1,6 +1,6 @@
|
|||||||
#!/usr/bin/python3 -i
|
#!/usr/bin/python3 -i
|
||||||
#
|
#
|
||||||
# Copyright 2013-2022 The Khronos Group Inc.
|
# Copyright 2013-2023 The Khronos Group Inc.
|
||||||
#
|
#
|
||||||
# SPDX-License-Identifier: Apache-2.0
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
@ -109,6 +109,8 @@ class VulkanConventions(ConventionsBase):
|
|||||||
[ r'_H_(26[45])_', r'_H\1_' ],
|
[ r'_H_(26[45])_', r'_H\1_' ],
|
||||||
[ r'_VULKAN_([0-9])([0-9])_', r'_VULKAN_\1_\2_' ],
|
[ r'_VULKAN_([0-9])([0-9])_', r'_VULKAN_\1_\2_' ],
|
||||||
[ r'_DIRECT_FB_', r'_DIRECTFB_' ],
|
[ r'_DIRECT_FB_', r'_DIRECTFB_' ],
|
||||||
|
[ r'_VULKAN_SC_10', r'_VULKAN_SC_1_0' ],
|
||||||
|
|
||||||
]
|
]
|
||||||
|
|
||||||
for subpat in subpats:
|
for subpat in subpats:
|
||||||
|
46
tests/CMakeLists.txt
Normal file
46
tests/CMakeLists.txt
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
# ~~~
|
||||||
|
# Copyright (c) 2022-2023 LunarG, Inc.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
# ~~~
|
||||||
|
|
||||||
|
# Test the non-API headers provided by this repo
|
||||||
|
# NOTE: For us testing just means that these header files compile
|
||||||
|
# with reasonable warnings.
|
||||||
|
|
||||||
|
message(STATUS "${PROJECT_NAME} = ${PROJECT_VERSION}")
|
||||||
|
|
||||||
|
set(CMAKE_C_STANDARD 99)
|
||||||
|
set(CMAKE_C_STANDARD_REQUIRED ON)
|
||||||
|
set(CMAKE_C_EXTENSIONS OFF)
|
||||||
|
|
||||||
|
if(${CMAKE_C_COMPILER_ID} MATCHES "(GNU|Clang)")
|
||||||
|
add_compile_options(
|
||||||
|
-Wpedantic
|
||||||
|
-Wall
|
||||||
|
-Wextra
|
||||||
|
-Werror
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# vk_icd.h
|
||||||
|
add_executable(vk_icd vk_icd.c)
|
||||||
|
target_link_libraries(vk_icd PRIVATE Vulkan::Headers)
|
||||||
|
|
||||||
|
# vk_layer.h
|
||||||
|
add_library(vk_layer MODULE vk_layer.c)
|
||||||
|
target_link_libraries(vk_layer PRIVATE Vulkan::Headers)
|
||||||
|
|
||||||
|
if (NOT TARGET Vulkan-Headers)
|
||||||
|
message(FATAL_ERROR "Backcompat for Vulkan-Headers target broken!")
|
||||||
|
endif()
|
32
tests/find_package/CMakeLists.txt
Normal file
32
tests/find_package/CMakeLists.txt
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
cmake_minimum_required(VERSION 3.14.2)
|
||||||
|
|
||||||
|
project(TEST_VULKAN_HEADERS_FIND_PACKAGE_SUPPORT LANGUAGES C)
|
||||||
|
|
||||||
|
find_package(VulkanHeaders REQUIRED CONFIG)
|
||||||
|
|
||||||
|
if (NOT TARGET Vulkan::Headers)
|
||||||
|
message(FATAL_ERROR "Vulkan::Headers target not defined")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if (NOT DEFINED VULKAN_HEADERS_REGISTRY_DIRECTORY)
|
||||||
|
message(FATAL_ERROR "VULKAN_HEADERS_REGISTRY_DIRECTORY not defined!")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if (NOT EXISTS "${VULKAN_HEADERS_REGISTRY_DIRECTORY}/vk.xml")
|
||||||
|
message(FATAL_ERROR "VULKAN_HEADERS_REGISTRY_DIRECTORY not valid!")
|
||||||
|
endif()
|
||||||
|
message(STATUS "VULKAN_HEADERS_REGISTRY_DIRECTORY = ${VULKAN_HEADERS_REGISTRY_DIRECTORY}")
|
||||||
|
|
||||||
|
if (NOT DEFINED VulkanHeaders_VERSION)
|
||||||
|
message(FATAL_ERROR "VulkanHeaders_VERSION not defined!")
|
||||||
|
endif()
|
||||||
|
message(STATUS "VulkanHeaders_VERSION = ${VulkanHeaders_VERSION}")
|
||||||
|
|
||||||
|
add_library(foobar STATIC)
|
||||||
|
|
||||||
|
target_link_libraries(foobar PRIVATE Vulkan::Headers)
|
||||||
|
|
||||||
|
target_sources(foobar PRIVATE
|
||||||
|
../vk_icd.c
|
||||||
|
../vk_layer.c
|
||||||
|
)
|
6
tests/vk_icd.c
Normal file
6
tests/vk_icd.c
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#include "vulkan/vk_icd.h"
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
6
tests/vk_layer.c
Normal file
6
tests/vk_layer.c
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#include "vulkan/vk_layer.h"
|
||||||
|
|
||||||
|
int foobar()
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user